You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2336 lines
83 KiB
2336 lines
83 KiB
var __accessCheck = (obj, member, msg) => { |
|
if (!member.has(obj)) |
|
throw TypeError("Cannot " + msg); |
|
}; |
|
var __privateGet = (obj, member, getter) => { |
|
__accessCheck(obj, member, "read from private field"); |
|
return getter ? getter.call(obj) : member.get(obj); |
|
}; |
|
var __privateAdd = (obj, member, value) => { |
|
if (member.has(obj)) |
|
throw TypeError("Cannot add the same private member more than once"); |
|
member instanceof WeakSet ? member.add(obj) : member.set(obj, value); |
|
}; |
|
var __privateSet = (obj, member, value, setter) => { |
|
__accessCheck(obj, member, "write to private field"); |
|
setter ? setter.call(obj, value) : member.set(obj, value); |
|
return value; |
|
}; |
|
var __privateMethod = (obj, member, method) => { |
|
__accessCheck(obj, member, "access private method"); |
|
return method; |
|
}; |
|
|
|
// src/comments.ts |
|
import ts2 from "typescript"; |
|
|
|
// src/tokens.ts |
|
import ts from "typescript"; |
|
function forEachToken(node, callback, sourceFile = node.getSourceFile()) { |
|
const queue = []; |
|
while (true) { |
|
if (ts.isTokenKind(node.kind)) { |
|
callback(node); |
|
} else if ( |
|
// eslint-disable-next-line deprecation/deprecation -- need for support of TS < 4.7 |
|
node.kind !== ts.SyntaxKind.JSDocComment |
|
) { |
|
const children = node.getChildren(sourceFile); |
|
if (children.length === 1) { |
|
node = children[0]; |
|
continue; |
|
} |
|
for (let i = children.length - 1; i >= 0; --i) { |
|
queue.push(children[i]); |
|
} |
|
} |
|
if (queue.length === 0) { |
|
break; |
|
} |
|
node = queue.pop(); |
|
} |
|
} |
|
|
|
// src/comments.ts |
|
function canHaveTrailingTrivia(token) { |
|
switch (token.kind) { |
|
case ts2.SyntaxKind.CloseBraceToken: |
|
return token.parent.kind !== ts2.SyntaxKind.JsxExpression || !isJsxElementOrFragment(token.parent.parent); |
|
case ts2.SyntaxKind.GreaterThanToken: |
|
switch (token.parent.kind) { |
|
case ts2.SyntaxKind.JsxOpeningElement: |
|
return token.end !== token.parent.end; |
|
case ts2.SyntaxKind.JsxOpeningFragment: |
|
return false; |
|
case ts2.SyntaxKind.JsxSelfClosingElement: |
|
return token.end !== token.parent.end || // if end is not equal, this is part of the type arguments list |
|
!isJsxElementOrFragment(token.parent.parent); |
|
case ts2.SyntaxKind.JsxClosingElement: |
|
case ts2.SyntaxKind.JsxClosingFragment: |
|
return !isJsxElementOrFragment(token.parent.parent.parent); |
|
} |
|
} |
|
return true; |
|
} |
|
function isJsxElementOrFragment(node) { |
|
return node.kind === ts2.SyntaxKind.JsxElement || node.kind === ts2.SyntaxKind.JsxFragment; |
|
} |
|
function forEachComment(node, callback, sourceFile = node.getSourceFile()) { |
|
const fullText = sourceFile.text; |
|
const notJsx = sourceFile.languageVariant !== ts2.LanguageVariant.JSX; |
|
return forEachToken( |
|
node, |
|
(token) => { |
|
if (token.pos === token.end) { |
|
return; |
|
} |
|
if (token.kind !== ts2.SyntaxKind.JsxText) { |
|
ts2.forEachLeadingCommentRange( |
|
fullText, |
|
// skip shebang at position 0 |
|
token.pos === 0 ? (ts2.getShebang(fullText) ?? "").length : token.pos, |
|
commentCallback |
|
); |
|
} |
|
if (notJsx || canHaveTrailingTrivia(token)) { |
|
return ts2.forEachTrailingCommentRange( |
|
fullText, |
|
token.end, |
|
commentCallback |
|
); |
|
} |
|
}, |
|
sourceFile |
|
); |
|
function commentCallback(pos, end, kind) { |
|
callback(fullText, { end, kind, pos }); |
|
} |
|
} |
|
|
|
// src/compilerOptions.ts |
|
import ts3 from "typescript"; |
|
function isCompilerOptionEnabled(options, option) { |
|
switch (option) { |
|
case "stripInternal": |
|
case "declarationMap": |
|
case "emitDeclarationOnly": |
|
return options[option] === true && isCompilerOptionEnabled(options, "declaration"); |
|
case "declaration": |
|
return options.declaration || isCompilerOptionEnabled(options, "composite"); |
|
case "incremental": |
|
return options.incremental === void 0 ? isCompilerOptionEnabled(options, "composite") : options.incremental; |
|
case "skipDefaultLibCheck": |
|
return options.skipDefaultLibCheck || isCompilerOptionEnabled(options, "skipLibCheck"); |
|
case "suppressImplicitAnyIndexErrors": |
|
return options.suppressImplicitAnyIndexErrors === true && isCompilerOptionEnabled(options, "noImplicitAny"); |
|
case "allowSyntheticDefaultImports": |
|
return options.allowSyntheticDefaultImports !== void 0 ? options.allowSyntheticDefaultImports : isCompilerOptionEnabled(options, "esModuleInterop") || options.module === ts3.ModuleKind.System; |
|
case "noUncheckedIndexedAccess": |
|
return options.noUncheckedIndexedAccess === true && isCompilerOptionEnabled(options, "strictNullChecks"); |
|
case "allowJs": |
|
return options.allowJs === void 0 ? isCompilerOptionEnabled(options, "checkJs") : options.allowJs; |
|
case "noImplicitAny": |
|
case "noImplicitThis": |
|
case "strictNullChecks": |
|
case "strictFunctionTypes": |
|
case "strictPropertyInitialization": |
|
case "alwaysStrict": |
|
case "strictBindCallApply": |
|
return isStrictCompilerOptionEnabled( |
|
options, |
|
option |
|
); |
|
} |
|
return options[option] === true; |
|
} |
|
function isStrictCompilerOptionEnabled(options, option) { |
|
return (options.strict ? options[option] !== false : options[option] === true) && (option !== "strictPropertyInitialization" || isStrictCompilerOptionEnabled(options, "strictNullChecks")); |
|
} |
|
|
|
// src/flags.ts |
|
import ts4 from "typescript"; |
|
function isFlagSet(allFlags, flag) { |
|
return (allFlags & flag) !== 0; |
|
} |
|
function isFlagSetOnObject(obj, flag) { |
|
return isFlagSet(obj.flags, flag); |
|
} |
|
function isModifierFlagSet(node, flag) { |
|
return isFlagSet(ts4.getCombinedModifierFlags(node), flag); |
|
} |
|
var isNodeFlagSet = isFlagSetOnObject; |
|
function isObjectFlagSet(objectType, flag) { |
|
return isFlagSet(objectType.objectFlags, flag); |
|
} |
|
var isSymbolFlagSet = isFlagSetOnObject; |
|
var isTypeFlagSet = isFlagSetOnObject; |
|
|
|
// src/modifiers.ts |
|
function includesModifier(modifiers, ...kinds) { |
|
if (modifiers === void 0) { |
|
return false; |
|
} |
|
for (const modifier of modifiers) { |
|
if (kinds.includes(modifier.kind)) { |
|
return true; |
|
} |
|
} |
|
return false; |
|
} |
|
|
|
// src/nodes/access.ts |
|
import ts6 from "typescript"; |
|
|
|
// src/syntax.ts |
|
import ts5 from "typescript"; |
|
function isAssignmentKind(kind) { |
|
return kind >= ts5.SyntaxKind.FirstAssignment && kind <= ts5.SyntaxKind.LastAssignment; |
|
} |
|
function isNumericPropertyName(name) { |
|
return String(+name) === name; |
|
} |
|
function charSize(ch) { |
|
return ch >= 65536 ? 2 : 1; |
|
} |
|
function isValidPropertyAccess(text, languageVersion = ts5.ScriptTarget.Latest) { |
|
if (text.length === 0) { |
|
return false; |
|
} |
|
let ch = text.codePointAt(0); |
|
if (!ts5.isIdentifierStart(ch, languageVersion)) { |
|
return false; |
|
} |
|
for (let i = charSize(ch); i < text.length; i += charSize(ch)) { |
|
ch = text.codePointAt(i); |
|
if (!ts5.isIdentifierPart(ch, languageVersion)) { |
|
return false; |
|
} |
|
} |
|
return true; |
|
} |
|
|
|
// src/nodes/access.ts |
|
var AccessKind = /* @__PURE__ */ ((AccessKind2) => { |
|
AccessKind2[AccessKind2["None"] = 0] = "None"; |
|
AccessKind2[AccessKind2["Read"] = 1] = "Read"; |
|
AccessKind2[AccessKind2["Write"] = 2] = "Write"; |
|
AccessKind2[AccessKind2["Delete"] = 4] = "Delete"; |
|
AccessKind2[AccessKind2["ReadWrite"] = 3] = "ReadWrite"; |
|
return AccessKind2; |
|
})(AccessKind || {}); |
|
function getAccessKind(node) { |
|
const parent = node.parent; |
|
switch (parent.kind) { |
|
case ts6.SyntaxKind.DeleteExpression: |
|
return 4 /* Delete */; |
|
case ts6.SyntaxKind.PostfixUnaryExpression: |
|
return 3 /* ReadWrite */; |
|
case ts6.SyntaxKind.PrefixUnaryExpression: |
|
return parent.operator === ts6.SyntaxKind.PlusPlusToken || parent.operator === ts6.SyntaxKind.MinusMinusToken ? 3 /* ReadWrite */ : 1 /* Read */; |
|
case ts6.SyntaxKind.BinaryExpression: |
|
return parent.right === node ? 1 /* Read */ : !isAssignmentKind(parent.operatorToken.kind) ? 1 /* Read */ : parent.operatorToken.kind === ts6.SyntaxKind.EqualsToken ? 2 /* Write */ : 3 /* ReadWrite */; |
|
case ts6.SyntaxKind.ShorthandPropertyAssignment: |
|
return parent.objectAssignmentInitializer === node ? 1 /* Read */ : isInDestructuringAssignment(parent) ? 2 /* Write */ : 1 /* Read */; |
|
case ts6.SyntaxKind.PropertyAssignment: |
|
return parent.name === node ? 0 /* None */ : isInDestructuringAssignment(parent) ? 2 /* Write */ : 1 /* Read */; |
|
case ts6.SyntaxKind.ArrayLiteralExpression: |
|
case ts6.SyntaxKind.SpreadElement: |
|
case ts6.SyntaxKind.SpreadAssignment: |
|
return isInDestructuringAssignment( |
|
parent |
|
) ? 2 /* Write */ : 1 /* Read */; |
|
case ts6.SyntaxKind.ParenthesizedExpression: |
|
case ts6.SyntaxKind.NonNullExpression: |
|
case ts6.SyntaxKind.TypeAssertionExpression: |
|
case ts6.SyntaxKind.AsExpression: |
|
return getAccessKind(parent); |
|
case ts6.SyntaxKind.ForOfStatement: |
|
case ts6.SyntaxKind.ForInStatement: |
|
return parent.initializer === node ? 2 /* Write */ : 1 /* Read */; |
|
case ts6.SyntaxKind.ExpressionWithTypeArguments: |
|
return parent.parent.token === ts6.SyntaxKind.ExtendsKeyword && parent.parent.parent.kind !== ts6.SyntaxKind.InterfaceDeclaration ? 1 /* Read */ : 0 /* None */; |
|
case ts6.SyntaxKind.ComputedPropertyName: |
|
case ts6.SyntaxKind.ExpressionStatement: |
|
case ts6.SyntaxKind.TypeOfExpression: |
|
case ts6.SyntaxKind.ElementAccessExpression: |
|
case ts6.SyntaxKind.ForStatement: |
|
case ts6.SyntaxKind.IfStatement: |
|
case ts6.SyntaxKind.DoStatement: |
|
case ts6.SyntaxKind.WhileStatement: |
|
case ts6.SyntaxKind.SwitchStatement: |
|
case ts6.SyntaxKind.WithStatement: |
|
case ts6.SyntaxKind.ThrowStatement: |
|
case ts6.SyntaxKind.CallExpression: |
|
case ts6.SyntaxKind.NewExpression: |
|
case ts6.SyntaxKind.TaggedTemplateExpression: |
|
case ts6.SyntaxKind.JsxExpression: |
|
case ts6.SyntaxKind.Decorator: |
|
case ts6.SyntaxKind.TemplateSpan: |
|
case ts6.SyntaxKind.JsxOpeningElement: |
|
case ts6.SyntaxKind.JsxSelfClosingElement: |
|
case ts6.SyntaxKind.JsxSpreadAttribute: |
|
case ts6.SyntaxKind.VoidExpression: |
|
case ts6.SyntaxKind.ReturnStatement: |
|
case ts6.SyntaxKind.AwaitExpression: |
|
case ts6.SyntaxKind.YieldExpression: |
|
case ts6.SyntaxKind.ConditionalExpression: |
|
case ts6.SyntaxKind.CaseClause: |
|
case ts6.SyntaxKind.JsxElement: |
|
return 1 /* Read */; |
|
case ts6.SyntaxKind.ArrowFunction: |
|
return parent.body === node ? 1 /* Read */ : 2 /* Write */; |
|
case ts6.SyntaxKind.PropertyDeclaration: |
|
case ts6.SyntaxKind.VariableDeclaration: |
|
case ts6.SyntaxKind.Parameter: |
|
case ts6.SyntaxKind.EnumMember: |
|
case ts6.SyntaxKind.BindingElement: |
|
case ts6.SyntaxKind.JsxAttribute: |
|
return parent.initializer === node ? 1 /* Read */ : 0 /* None */; |
|
case ts6.SyntaxKind.PropertyAccessExpression: |
|
return parent.expression === node ? 1 /* Read */ : 0 /* None */; |
|
case ts6.SyntaxKind.ExportAssignment: |
|
return parent.isExportEquals ? 1 /* Read */ : 0 /* None */; |
|
} |
|
return 0 /* None */; |
|
} |
|
function isInDestructuringAssignment(node) { |
|
switch (node.kind) { |
|
case ts6.SyntaxKind.ShorthandPropertyAssignment: |
|
if (node.objectAssignmentInitializer !== void 0) { |
|
return true; |
|
} |
|
case ts6.SyntaxKind.PropertyAssignment: |
|
case ts6.SyntaxKind.SpreadAssignment: |
|
node = node.parent; |
|
break; |
|
case ts6.SyntaxKind.SpreadElement: |
|
if (node.parent.kind !== ts6.SyntaxKind.ArrayLiteralExpression) { |
|
return false; |
|
} |
|
node = node.parent; |
|
} |
|
while (true) { |
|
switch (node.parent.kind) { |
|
case ts6.SyntaxKind.BinaryExpression: |
|
return node.parent.left === node && node.parent.operatorToken.kind === ts6.SyntaxKind.EqualsToken; |
|
case ts6.SyntaxKind.ForOfStatement: |
|
return node.parent.initializer === node; |
|
case ts6.SyntaxKind.ArrayLiteralExpression: |
|
case ts6.SyntaxKind.ObjectLiteralExpression: |
|
node = node.parent; |
|
break; |
|
case ts6.SyntaxKind.SpreadAssignment: |
|
case ts6.SyntaxKind.PropertyAssignment: |
|
node = node.parent.parent; |
|
break; |
|
case ts6.SyntaxKind.SpreadElement: |
|
if (node.parent.parent.kind !== ts6.SyntaxKind.ArrayLiteralExpression) { |
|
return false; |
|
} |
|
node = node.parent.parent; |
|
break; |
|
default: |
|
return false; |
|
} |
|
} |
|
} |
|
|
|
// src/nodes/typeGuards/compound.ts |
|
import ts10 from "typescript"; |
|
|
|
// src/nodes/typeGuards/single.ts |
|
import ts7 from "typescript"; |
|
function isAbstractKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AbstractKeyword; |
|
} |
|
function isAccessorKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AccessorKeyword; |
|
} |
|
function isAnyKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AnyKeyword; |
|
} |
|
function isAssertKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AssertKeyword; |
|
} |
|
function isAssertsKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AssertsKeyword; |
|
} |
|
function isAsyncKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AsyncKeyword; |
|
} |
|
function isAwaitKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.AwaitKeyword; |
|
} |
|
function isBigIntKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.BigIntKeyword; |
|
} |
|
function isBooleanKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.BooleanKeyword; |
|
} |
|
function isColonToken(node) { |
|
return node.kind === ts7.SyntaxKind.ColonToken; |
|
} |
|
function isConstKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ConstKeyword; |
|
} |
|
function isDeclareKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.DeclareKeyword; |
|
} |
|
function isDefaultKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.DefaultKeyword; |
|
} |
|
function isDotToken(node) { |
|
return node.kind === ts7.SyntaxKind.DotToken; |
|
} |
|
function isEndOfFileToken(node) { |
|
return node.kind === ts7.SyntaxKind.EndOfFileToken; |
|
} |
|
function isEqualsGreaterThanToken(node) { |
|
return node.kind === ts7.SyntaxKind.EqualsGreaterThanToken; |
|
} |
|
function isEqualsToken(node) { |
|
return node.kind === ts7.SyntaxKind.EqualsToken; |
|
} |
|
function isExclamationToken(node) { |
|
return node.kind === ts7.SyntaxKind.ExclamationToken; |
|
} |
|
function isExportKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ExportKeyword; |
|
} |
|
function isFalseKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.FalseKeyword; |
|
} |
|
function isFalseLiteral(node) { |
|
return node.kind === ts7.SyntaxKind.FalseKeyword; |
|
} |
|
function isImportExpression(node) { |
|
return node.kind === ts7.SyntaxKind.ImportKeyword; |
|
} |
|
function isImportKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ImportKeyword; |
|
} |
|
function isInKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.InKeyword; |
|
} |
|
function isInputFiles(node) { |
|
return node.kind === ts7.SyntaxKind.InputFiles; |
|
} |
|
function isJSDocText(node) { |
|
return node.kind === ts7.SyntaxKind.JSDocText; |
|
} |
|
function isJsonMinusNumericLiteral(node) { |
|
return node.kind === ts7.SyntaxKind.PrefixUnaryExpression; |
|
} |
|
function isNeverKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.NeverKeyword; |
|
} |
|
function isNullKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.NullKeyword; |
|
} |
|
function isNullLiteral(node) { |
|
return node.kind === ts7.SyntaxKind.NullKeyword; |
|
} |
|
function isNumberKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.NumberKeyword; |
|
} |
|
function isObjectKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ObjectKeyword; |
|
} |
|
function isOutKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.OutKeyword; |
|
} |
|
function isOverrideKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.OverrideKeyword; |
|
} |
|
function isPrivateKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.PrivateKeyword; |
|
} |
|
function isProtectedKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ProtectedKeyword; |
|
} |
|
function isPublicKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.PublicKeyword; |
|
} |
|
function isQuestionDotToken(node) { |
|
return node.kind === ts7.SyntaxKind.QuestionDotToken; |
|
} |
|
function isQuestionToken(node) { |
|
return node.kind === ts7.SyntaxKind.QuestionToken; |
|
} |
|
function isReadonlyKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ReadonlyKeyword; |
|
} |
|
function isStaticKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.StaticKeyword; |
|
} |
|
function isStringKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.StringKeyword; |
|
} |
|
function isSuperExpression(node) { |
|
return node.kind === ts7.SyntaxKind.SuperKeyword; |
|
} |
|
function isSuperKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.SuperKeyword; |
|
} |
|
function isSymbolKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.SymbolKeyword; |
|
} |
|
function isSyntaxList(node) { |
|
return node.kind === ts7.SyntaxKind.SyntaxList; |
|
} |
|
function isThisExpression(node) { |
|
return node.kind === ts7.SyntaxKind.ThisKeyword; |
|
} |
|
function isThisKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.ThisKeyword; |
|
} |
|
function isTrueKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.TrueKeyword; |
|
} |
|
function isTrueLiteral(node) { |
|
return node.kind === ts7.SyntaxKind.TrueKeyword; |
|
} |
|
function isUndefinedKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.UndefinedKeyword; |
|
} |
|
function isUnknownKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.UnknownKeyword; |
|
} |
|
function isUnparsedPrologue(node) { |
|
return node.kind === ts7.SyntaxKind.UnparsedPrologue; |
|
} |
|
function isUnparsedSyntheticReference(node) { |
|
return node.kind === ts7.SyntaxKind.UnparsedSyntheticReference; |
|
} |
|
function isVoidKeyword(node) { |
|
return node.kind === ts7.SyntaxKind.VoidKeyword; |
|
} |
|
|
|
// src/nodes/typeGuards/union.ts |
|
import ts9 from "typescript"; |
|
|
|
// src/utils.ts |
|
import ts8 from "typescript"; |
|
var [tsMajor, tsMinor] = ts8.versionMajorMinor.split(".").map((raw) => Number.parseInt(raw, 10)); |
|
function isTsVersionAtLeast(major, minor = 0) { |
|
return tsMajor > major || tsMajor === major && tsMinor >= minor; |
|
} |
|
|
|
// src/nodes/typeGuards/union.ts |
|
function isAccessExpression(node) { |
|
return ts9.isPropertyAccessExpression(node) || ts9.isElementAccessExpression(node); |
|
} |
|
function isAccessibilityModifier(node) { |
|
return isPublicKeyword(node) || isPrivateKeyword(node) || isProtectedKeyword(node); |
|
} |
|
function isAccessorDeclaration(node) { |
|
return ts9.isGetAccessorDeclaration(node) || ts9.isSetAccessorDeclaration(node); |
|
} |
|
function isArrayBindingElement(node) { |
|
return ts9.isBindingElement(node) || ts9.isOmittedExpression(node); |
|
} |
|
function isArrayBindingOrAssignmentPattern(node) { |
|
return ts9.isArrayBindingPattern(node) || ts9.isArrayLiteralExpression(node); |
|
} |
|
function isAssignmentPattern(node) { |
|
return ts9.isObjectLiteralExpression(node) || ts9.isArrayLiteralExpression(node); |
|
} |
|
function isBindingOrAssignmentElementRestIndicator(node) { |
|
if (ts9.isSpreadElement(node) || ts9.isSpreadAssignment(node)) { |
|
return true; |
|
} |
|
if (isTsVersionAtLeast(4, 4)) { |
|
return ts9.isDotDotDotToken(node); |
|
} |
|
return false; |
|
} |
|
function isBindingOrAssignmentElementTarget(node) { |
|
return isBindingOrAssignmentPattern(node) || ts9.isIdentifier(node) || ts9.isPropertyAccessExpression(node) || ts9.isElementAccessExpression(node) || ts9.isOmittedExpression(node); |
|
} |
|
function isBindingOrAssignmentPattern(node) { |
|
return isObjectBindingOrAssignmentPattern(node) || isArrayBindingOrAssignmentPattern(node); |
|
} |
|
function isBindingPattern(node) { |
|
return ts9.isObjectBindingPattern(node) || ts9.isArrayBindingPattern(node); |
|
} |
|
function isBlockLike(node) { |
|
return ts9.isSourceFile(node) || ts9.isBlock(node) || ts9.isModuleBlock(node) || ts9.isCaseOrDefaultClause(node); |
|
} |
|
function isBooleanLiteral(node) { |
|
return isTrueLiteral(node) || isFalseLiteral(node); |
|
} |
|
function isClassLikeDeclaration(node) { |
|
return ts9.isClassDeclaration(node) || ts9.isClassExpression(node); |
|
} |
|
function isClassMemberModifier(node) { |
|
return isAccessibilityModifier(node) || isReadonlyKeyword(node) || isStaticKeyword(node) || isAccessorKeyword(node); |
|
} |
|
function isDeclarationName(node) { |
|
return ts9.isIdentifier(node) || ts9.isPrivateIdentifier(node) || ts9.isStringLiteralLike(node) || ts9.isNumericLiteral(node) || ts9.isComputedPropertyName(node) || ts9.isElementAccessExpression(node) || isBindingPattern(node) || isEntityNameExpression(node); |
|
} |
|
function isDeclarationWithTypeParameterChildren(node) { |
|
return isSignatureDeclaration(node) || // eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts <5 |
|
isClassLikeDeclaration(node) || ts9.isInterfaceDeclaration(node) || ts9.isTypeAliasDeclaration(node) || ts9.isJSDocTemplateTag(node); |
|
} |
|
function isDeclarationWithTypeParameters(node) { |
|
return isDeclarationWithTypeParameterChildren(node) || ts9.isJSDocTypedefTag(node) || ts9.isJSDocCallbackTag(node) || ts9.isJSDocSignature(node); |
|
} |
|
function isDestructuringPattern(node) { |
|
return isBindingPattern(node) || ts9.isObjectLiteralExpression(node) || ts9.isArrayLiteralExpression(node); |
|
} |
|
function isEntityNameExpression(node) { |
|
return ts9.isIdentifier(node) || isPropertyAccessEntityNameExpression(node); |
|
} |
|
function isEntityNameOrEntityNameExpression(node) { |
|
return ts9.isEntityName(node) || isEntityNameExpression(node); |
|
} |
|
function isForInOrOfStatement(node) { |
|
return ts9.isForInStatement(node) || ts9.isForOfStatement(node); |
|
} |
|
function isFunctionLikeDeclaration(node) { |
|
return ts9.isFunctionDeclaration(node) || ts9.isMethodDeclaration(node) || ts9.isGetAccessorDeclaration(node) || ts9.isSetAccessorDeclaration(node) || ts9.isConstructorDeclaration(node) || ts9.isFunctionExpression(node) || ts9.isArrowFunction(node); |
|
} |
|
function hasDecorators(node) { |
|
return ts9.isParameter(node) || ts9.isPropertyDeclaration(node) || ts9.isMethodDeclaration(node) || ts9.isGetAccessorDeclaration(node) || ts9.isSetAccessorDeclaration(node) || ts9.isClassExpression(node) || ts9.isClassDeclaration(node); |
|
} |
|
function hasExpressionInitializer(node) { |
|
return ts9.isVariableDeclaration(node) || ts9.isParameter(node) || ts9.isBindingElement(node) || ts9.isPropertyDeclaration(node) || ts9.isPropertyAssignment(node) || ts9.isEnumMember(node); |
|
} |
|
function hasInitializer(node) { |
|
return hasExpressionInitializer(node) || ts9.isForStatement(node) || ts9.isForInStatement(node) || ts9.isForOfStatement(node) || ts9.isJsxAttribute(node); |
|
} |
|
function hasJSDoc(node) { |
|
if ( |
|
// eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts <5 |
|
isAccessorDeclaration(node) || ts9.isArrowFunction(node) || ts9.isBlock(node) || ts9.isBreakStatement(node) || ts9.isCallSignatureDeclaration(node) || ts9.isCaseClause(node) || // eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts <5 |
|
isClassLikeDeclaration(node) || ts9.isConstructorDeclaration(node) || ts9.isConstructorTypeNode(node) || ts9.isConstructSignatureDeclaration(node) || ts9.isContinueStatement(node) || ts9.isDebuggerStatement(node) || ts9.isDoStatement(node) || ts9.isEmptyStatement(node) || isEndOfFileToken(node) || ts9.isEnumDeclaration(node) || ts9.isEnumMember(node) || ts9.isExportAssignment(node) || ts9.isExportDeclaration(node) || ts9.isExportSpecifier(node) || ts9.isExpressionStatement(node) || ts9.isForInStatement(node) || ts9.isForOfStatement(node) || ts9.isForStatement(node) || ts9.isFunctionDeclaration(node) || ts9.isFunctionExpression(node) || ts9.isFunctionTypeNode(node) || ts9.isIfStatement(node) || ts9.isImportDeclaration(node) || ts9.isImportEqualsDeclaration(node) || ts9.isIndexSignatureDeclaration(node) || ts9.isInterfaceDeclaration(node) || ts9.isJSDocFunctionType(node) || ts9.isLabeledStatement(node) || ts9.isMethodDeclaration(node) || ts9.isMethodSignature(node) || ts9.isModuleDeclaration(node) || ts9.isNamedTupleMember(node) || ts9.isNamespaceExportDeclaration(node) || ts9.isParameter(node) || ts9.isParenthesizedExpression(node) || ts9.isPropertyAssignment(node) || ts9.isPropertyDeclaration(node) || ts9.isPropertySignature(node) || ts9.isReturnStatement(node) || ts9.isShorthandPropertyAssignment(node) || ts9.isSpreadAssignment(node) || ts9.isSwitchStatement(node) || ts9.isThrowStatement(node) || ts9.isTryStatement(node) || ts9.isTypeAliasDeclaration(node) || ts9.isVariableDeclaration(node) || ts9.isVariableStatement(node) || ts9.isWhileStatement(node) || ts9.isWithStatement(node) |
|
) { |
|
return true; |
|
} |
|
if (isTsVersionAtLeast(4, 4) && ts9.isClassStaticBlockDeclaration(node)) { |
|
return true; |
|
} |
|
if (isTsVersionAtLeast(5, 0) && (ts9.isBinaryExpression(node) || ts9.isElementAccessExpression(node) || ts9.isIdentifier(node) || ts9.isJSDocSignature(node) || ts9.isObjectLiteralExpression(node) || ts9.isPropertyAccessExpression(node) || ts9.isTypeParameterDeclaration(node))) { |
|
return true; |
|
} |
|
return false; |
|
} |
|
function hasModifiers(node) { |
|
return ts9.isTypeParameterDeclaration(node) || ts9.isParameter(node) || ts9.isConstructorTypeNode(node) || ts9.isPropertySignature(node) || ts9.isPropertyDeclaration(node) || ts9.isMethodSignature(node) || ts9.isMethodDeclaration(node) || ts9.isConstructorDeclaration(node) || ts9.isGetAccessorDeclaration(node) || ts9.isSetAccessorDeclaration(node) || ts9.isIndexSignatureDeclaration(node) || ts9.isFunctionExpression(node) || ts9.isArrowFunction(node) || ts9.isClassExpression(node) || ts9.isVariableStatement(node) || ts9.isFunctionDeclaration(node) || ts9.isClassDeclaration(node) || ts9.isInterfaceDeclaration(node) || ts9.isTypeAliasDeclaration(node) || ts9.isEnumDeclaration(node) || ts9.isModuleDeclaration(node) || ts9.isImportEqualsDeclaration(node) || ts9.isImportDeclaration(node) || ts9.isExportAssignment(node) || ts9.isExportDeclaration(node); |
|
} |
|
function hasType(node) { |
|
return isSignatureDeclaration(node) || ts9.isVariableDeclaration(node) || ts9.isParameter(node) || ts9.isPropertySignature(node) || ts9.isPropertyDeclaration(node) || ts9.isTypePredicateNode(node) || ts9.isParenthesizedTypeNode(node) || ts9.isTypeOperatorNode(node) || ts9.isMappedTypeNode(node) || ts9.isAssertionExpression(node) || ts9.isTypeAliasDeclaration(node) || ts9.isJSDocTypeExpression(node) || ts9.isJSDocNonNullableType(node) || ts9.isJSDocNullableType(node) || ts9.isJSDocOptionalType(node) || ts9.isJSDocVariadicType(node); |
|
} |
|
function hasTypeArguments(node) { |
|
return ts9.isCallExpression(node) || ts9.isNewExpression(node) || ts9.isTaggedTemplateExpression(node) || ts9.isJsxOpeningElement(node) || ts9.isJsxSelfClosingElement(node); |
|
} |
|
function isJSDocComment(node) { |
|
if (isJSDocText(node)) { |
|
return true; |
|
} |
|
if (isTsVersionAtLeast(4, 4)) { |
|
return ts9.isJSDocLink(node) || ts9.isJSDocLinkCode(node) || ts9.isJSDocLinkPlain(node); |
|
} |
|
return false; |
|
} |
|
function isJSDocNamespaceBody(node) { |
|
return ts9.isIdentifier(node) || isJSDocNamespaceDeclaration(node); |
|
} |
|
function isJSDocTypeReferencingNode(node) { |
|
return ts9.isJSDocVariadicType(node) || ts9.isJSDocOptionalType(node) || ts9.isJSDocNullableType(node) || ts9.isJSDocNonNullableType(node); |
|
} |
|
function isJsonObjectExpression(node) { |
|
return ts9.isObjectLiteralExpression(node) || ts9.isArrayLiteralExpression(node) || isJsonMinusNumericLiteral(node) || ts9.isNumericLiteral(node) || ts9.isStringLiteral(node) || isBooleanLiteral(node) || isNullLiteral(node); |
|
} |
|
function isJsxAttributeLike(node) { |
|
return ts9.isJsxAttribute(node) || ts9.isJsxSpreadAttribute(node); |
|
} |
|
function isJsxAttributeValue(node) { |
|
return ts9.isStringLiteral(node) || ts9.isJsxExpression(node) || ts9.isJsxElement(node) || ts9.isJsxSelfClosingElement(node) || ts9.isJsxFragment(node); |
|
} |
|
function isJsxChild(node) { |
|
return ts9.isJsxText(node) || ts9.isJsxExpression(node) || ts9.isJsxElement(node) || ts9.isJsxSelfClosingElement(node) || ts9.isJsxFragment(node); |
|
} |
|
function isJsxTagNameExpression(node) { |
|
return ts9.isIdentifier(node) || isThisExpression(node) || isJsxTagNamePropertyAccess(node); |
|
} |
|
function isLiteralToken(node) { |
|
return ts9.isNumericLiteral(node) || ts9.isBigIntLiteral(node) || ts9.isStringLiteral(node) || ts9.isJsxText(node) || ts9.isRegularExpressionLiteral(node) || ts9.isNoSubstitutionTemplateLiteral(node); |
|
} |
|
function isModuleBody(node) { |
|
return isNamespaceBody(node) || isJSDocNamespaceBody(node); |
|
} |
|
function isModuleName(node) { |
|
return ts9.isIdentifier(node) || ts9.isStringLiteral(node); |
|
} |
|
function isModuleReference(node) { |
|
return ts9.isEntityName(node) || ts9.isExternalModuleReference(node); |
|
} |
|
function isNamedImportBindings(node) { |
|
return ts9.isNamespaceImport(node) || ts9.isNamedImports(node); |
|
} |
|
function isNamedImportsOrExports(node) { |
|
return ts9.isNamedImports(node) || ts9.isNamedExports(node); |
|
} |
|
function isNamespaceBody(node) { |
|
return ts9.isModuleBlock(node) || isNamespaceDeclaration(node); |
|
} |
|
function isObjectBindingOrAssignmentElement(node) { |
|
return ts9.isBindingElement(node) || ts9.isPropertyAssignment(node) || ts9.isShorthandPropertyAssignment(node) || ts9.isSpreadAssignment(node); |
|
} |
|
function isObjectBindingOrAssignmentPattern(node) { |
|
return ts9.isObjectBindingPattern(node) || ts9.isObjectLiteralExpression(node); |
|
} |
|
function isObjectTypeDeclaration(node) { |
|
return ( |
|
// eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts <5 |
|
isClassLikeDeclaration(node) || ts9.isInterfaceDeclaration(node) || ts9.isTypeLiteralNode(node) |
|
); |
|
} |
|
function isParameterPropertyModifier(node) { |
|
return isAccessibilityModifier(node) || isReadonlyKeyword(node); |
|
} |
|
function isPropertyNameLiteral(node) { |
|
return ts9.isIdentifier(node) || ts9.isStringLiteralLike(node) || ts9.isNumericLiteral(node); |
|
} |
|
function isPseudoLiteralToken(node) { |
|
return ts9.isTemplateHead(node) || ts9.isTemplateMiddle(node) || ts9.isTemplateTail(node); |
|
} |
|
function isSignatureDeclaration(node) { |
|
return ts9.isCallSignatureDeclaration(node) || ts9.isConstructSignatureDeclaration(node) || ts9.isMethodSignature(node) || ts9.isIndexSignatureDeclaration(node) || ts9.isFunctionTypeNode(node) || ts9.isConstructorTypeNode(node) || ts9.isJSDocFunctionType(node) || ts9.isFunctionDeclaration(node) || ts9.isMethodDeclaration(node) || ts9.isConstructorDeclaration(node) || // eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts <5 |
|
isAccessorDeclaration(node) || ts9.isFunctionExpression(node) || ts9.isArrowFunction(node); |
|
} |
|
function isSuperProperty(node) { |
|
return isSuperPropertyAccessExpression(node) || isSuperElementAccessExpression(node); |
|
} |
|
function isTypeOnlyCompatibleAliasDeclaration(node) { |
|
if (ts9.isImportClause(node) || ts9.isImportEqualsDeclaration(node) || ts9.isNamespaceImport(node) || ts9.isImportOrExportSpecifier(node)) { |
|
return true; |
|
} |
|
if (isTsVersionAtLeast(5, 0) && (ts9.isExportDeclaration(node) || ts9.isNamespaceExport(node))) { |
|
return true; |
|
} |
|
return false; |
|
} |
|
function isTypeReferenceType(node) { |
|
return ts9.isTypeReferenceNode(node) || ts9.isExpressionWithTypeArguments(node); |
|
} |
|
function isUnionOrIntersectionTypeNode(node) { |
|
return ts9.isUnionTypeNode(node) || ts9.isIntersectionTypeNode(node); |
|
} |
|
function isUnparsedSourceText(node) { |
|
return ts9.isUnparsedPrepend(node) || ts9.isUnparsedTextLike(node); |
|
} |
|
function isVariableLikeDeclaration(node) { |
|
return ts9.isVariableDeclaration(node) || ts9.isParameter(node) || ts9.isBindingElement(node) || ts9.isPropertyDeclaration(node) || ts9.isPropertyAssignment(node) || ts9.isPropertySignature(node) || ts9.isJsxAttribute(node) || ts9.isShorthandPropertyAssignment(node) || ts9.isEnumMember(node) || ts9.isJSDocPropertyTag(node) || ts9.isJSDocParameterTag(node); |
|
} |
|
|
|
// src/nodes/typeGuards/compound.ts |
|
function isConstAssertionExpression(node) { |
|
return ts10.isTypeReferenceNode(node.type) && ts10.isIdentifier(node.type.typeName) && node.type.typeName.escapedText === "const"; |
|
} |
|
function isIterationStatement(node) { |
|
switch (node.kind) { |
|
case ts10.SyntaxKind.DoStatement: |
|
case ts10.SyntaxKind.ForInStatement: |
|
case ts10.SyntaxKind.ForOfStatement: |
|
case ts10.SyntaxKind.ForStatement: |
|
case ts10.SyntaxKind.WhileStatement: |
|
return true; |
|
default: |
|
return false; |
|
} |
|
} |
|
function isJSDocNamespaceDeclaration(node) { |
|
return ts10.isModuleDeclaration(node) && ts10.isIdentifier(node.name) && (node.body === void 0 || isJSDocNamespaceBody(node.body)); |
|
} |
|
function isJsxTagNamePropertyAccess(node) { |
|
return ts10.isPropertyAccessExpression(node) && // eslint-disable-next-line deprecation/deprecation -- Keep compatibility with ts < 5 |
|
isJsxTagNameExpression(node.expression); |
|
} |
|
function isNamedDeclarationWithName(node) { |
|
return "name" in node && node.name !== void 0 && node.name !== null && isDeclarationName(node.name); |
|
} |
|
function isNamespaceDeclaration(node) { |
|
return ts10.isModuleDeclaration(node) && ts10.isIdentifier(node.name) && node.body !== void 0 && isNamespaceBody(node.body); |
|
} |
|
function isNumericOrStringLikeLiteral(node) { |
|
switch (node.kind) { |
|
case ts10.SyntaxKind.StringLiteral: |
|
case ts10.SyntaxKind.NumericLiteral: |
|
case ts10.SyntaxKind.NoSubstitutionTemplateLiteral: |
|
return true; |
|
default: |
|
return false; |
|
} |
|
} |
|
function isPropertyAccessEntityNameExpression(node) { |
|
return ts10.isPropertyAccessExpression(node) && ts10.isIdentifier(node.name) && isEntityNameExpression(node.expression); |
|
} |
|
function isSuperElementAccessExpression(node) { |
|
return ts10.isElementAccessExpression(node) && isSuperExpression(node.expression); |
|
} |
|
function isSuperPropertyAccessExpression(node) { |
|
return ts10.isPropertyAccessExpression(node) && isSuperExpression(node.expression); |
|
} |
|
|
|
// src/scopes.ts |
|
import ts11 from "typescript"; |
|
function isFunctionScopeBoundary(node) { |
|
switch (node.kind) { |
|
case ts11.SyntaxKind.FunctionExpression: |
|
case ts11.SyntaxKind.ArrowFunction: |
|
case ts11.SyntaxKind.Constructor: |
|
case ts11.SyntaxKind.ModuleDeclaration: |
|
case ts11.SyntaxKind.ClassDeclaration: |
|
case ts11.SyntaxKind.ClassExpression: |
|
case ts11.SyntaxKind.EnumDeclaration: |
|
case ts11.SyntaxKind.MethodDeclaration: |
|
case ts11.SyntaxKind.FunctionDeclaration: |
|
case ts11.SyntaxKind.GetAccessor: |
|
case ts11.SyntaxKind.SetAccessor: |
|
case ts11.SyntaxKind.MethodSignature: |
|
case ts11.SyntaxKind.CallSignature: |
|
case ts11.SyntaxKind.ConstructSignature: |
|
case ts11.SyntaxKind.ConstructorType: |
|
case ts11.SyntaxKind.FunctionType: |
|
return true; |
|
case ts11.SyntaxKind.SourceFile: |
|
return ts11.isExternalModule(node); |
|
default: |
|
return false; |
|
} |
|
} |
|
|
|
// src/types/getters.ts |
|
import ts16 from "typescript"; |
|
|
|
// src/types/typeGuards/intrinsic.ts |
|
import ts12 from "typescript"; |
|
function isIntrinsicAnyType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Any); |
|
} |
|
function isIntrinsicBooleanType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Boolean); |
|
} |
|
function isIntrinsicBigIntType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.BigInt); |
|
} |
|
function isIntrinsicErrorType(type) { |
|
return isIntrinsicType(type) && type.intrinsicName === "error"; |
|
} |
|
function isIntrinsicESSymbolType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.ESSymbol); |
|
} |
|
var IntrinsicTypeFlags = ts12.TypeFlags.Intrinsic ?? ts12.TypeFlags.Any | ts12.TypeFlags.Unknown | ts12.TypeFlags.String | ts12.TypeFlags.Number | ts12.TypeFlags.BigInt | ts12.TypeFlags.Boolean | ts12.TypeFlags.BooleanLiteral | ts12.TypeFlags.ESSymbol | ts12.TypeFlags.Void | ts12.TypeFlags.Undefined | ts12.TypeFlags.Null | ts12.TypeFlags.Never | ts12.TypeFlags.NonPrimitive; |
|
function isIntrinsicType(type) { |
|
return isTypeFlagSet(type, IntrinsicTypeFlags); |
|
} |
|
function isIntrinsicNeverType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Never); |
|
} |
|
function isIntrinsicNonPrimitiveType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.NonPrimitive); |
|
} |
|
function isIntrinsicNullType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Null); |
|
} |
|
function isIntrinsicNumberType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Number); |
|
} |
|
function isIntrinsicStringType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.String); |
|
} |
|
function isIntrinsicUndefinedType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Undefined); |
|
} |
|
function isIntrinsicUnknownType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Unknown); |
|
} |
|
function isIntrinsicVoidType(type) { |
|
return isTypeFlagSet(type, ts12.TypeFlags.Void); |
|
} |
|
|
|
// src/types/typeGuards/objects.ts |
|
import ts14 from "typescript"; |
|
|
|
// src/types/typeGuards/single.ts |
|
import ts13 from "typescript"; |
|
function isConditionalType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Conditional); |
|
} |
|
function isEnumType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Enum); |
|
} |
|
function isFreshableType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Freshable); |
|
} |
|
function isIndexType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Index); |
|
} |
|
function isIndexedAccessType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.IndexedAccess); |
|
} |
|
function isInstantiableType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Instantiable); |
|
} |
|
function isIntersectionType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Intersection); |
|
} |
|
function isObjectType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Object); |
|
} |
|
function isStringMappingType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.StringMapping); |
|
} |
|
function isSubstitutionType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Substitution); |
|
} |
|
function isTypeParameter(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.TypeParameter); |
|
} |
|
function isTypeVariable(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.TypeVariable); |
|
} |
|
function isUnionType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.Union); |
|
} |
|
function isUnionOrIntersectionType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.UnionOrIntersection); |
|
} |
|
function isUniqueESSymbolType(type) { |
|
return isTypeFlagSet(type, ts13.TypeFlags.UniqueESSymbol); |
|
} |
|
|
|
// src/types/typeGuards/objects.ts |
|
function isEvolvingArrayType(type) { |
|
return isObjectType(type) && isObjectFlagSet(type, ts14.ObjectFlags.EvolvingArray); |
|
} |
|
function isTupleType(type) { |
|
return isObjectType(type) && isObjectFlagSet(type, ts14.ObjectFlags.Tuple); |
|
} |
|
function isTypeReference(type) { |
|
return isObjectType(type) && isObjectFlagSet(type, ts14.ObjectFlags.Reference); |
|
} |
|
|
|
// src/types/typeGuards/compound.ts |
|
function isFreshableIntrinsicType(type) { |
|
return isIntrinsicType(type) && isFreshableType(type); |
|
} |
|
function isTupleTypeReference(type) { |
|
return isTypeReference(type) && isTupleType(type.target); |
|
} |
|
|
|
// src/types/typeGuards/literal.ts |
|
import ts15 from "typescript"; |
|
function isBooleanLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.BooleanLiteral); |
|
} |
|
function isBigIntLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.BigIntLiteral); |
|
} |
|
function isFalseLiteralType(type) { |
|
return isBooleanLiteralType(type) && type.intrinsicName === "false"; |
|
} |
|
function isLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.Literal); |
|
} |
|
function isNumberLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.NumberLiteral); |
|
} |
|
function isStringLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.StringLiteral); |
|
} |
|
function isTemplateLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.TemplateLiteral); |
|
} |
|
function isTrueLiteralType(type) { |
|
return isBooleanLiteralType(type) && type.intrinsicName === "true"; |
|
} |
|
function isUnknownLiteralType(type) { |
|
return isTypeFlagSet(type, ts15.TypeFlags.Literal); |
|
} |
|
|
|
// src/types/getters.ts |
|
function getCallSignaturesOfType(type) { |
|
if (isUnionType(type)) { |
|
const signatures = []; |
|
for (const subType of type.types) { |
|
signatures.push(...getCallSignaturesOfType(subType)); |
|
} |
|
return signatures; |
|
} |
|
if (isIntersectionType(type)) { |
|
let signatures; |
|
for (const subType of type.types) { |
|
const sig = getCallSignaturesOfType(subType); |
|
if (sig.length !== 0) { |
|
if (signatures !== void 0) { |
|
return []; |
|
} |
|
signatures = sig; |
|
} |
|
} |
|
return signatures === void 0 ? [] : signatures; |
|
} |
|
return type.getCallSignatures(); |
|
} |
|
function getPropertyOfType(type, name) { |
|
if (!name.startsWith("__")) { |
|
return type.getProperty(name); |
|
} |
|
return type.getProperties().find((s) => s.escapedName === name); |
|
} |
|
function getWellKnownSymbolPropertyOfType(type, wellKnownSymbolName, typeChecker) { |
|
const prefix = "__@" + wellKnownSymbolName; |
|
for (const prop of type.getProperties()) { |
|
if (!prop.name.startsWith(prefix)) { |
|
continue; |
|
} |
|
const declaration = prop.valueDeclaration ?? prop.getDeclarations()[0]; |
|
if (!isNamedDeclarationWithName(declaration) || declaration.name === void 0 || !ts16.isComputedPropertyName(declaration.name)) { |
|
continue; |
|
} |
|
const globalSymbol = typeChecker.getApparentType( |
|
typeChecker.getTypeAtLocation(declaration.name.expression) |
|
).symbol; |
|
if (prop.escapedName === getPropertyNameOfWellKnownSymbol( |
|
typeChecker, |
|
globalSymbol, |
|
wellKnownSymbolName |
|
)) { |
|
return prop; |
|
} |
|
} |
|
return void 0; |
|
} |
|
function getPropertyNameOfWellKnownSymbol(typeChecker, symbolConstructor, symbolName) { |
|
const knownSymbol = symbolConstructor && typeChecker.getTypeOfSymbolAtLocation( |
|
symbolConstructor, |
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-unsafe-member-access |
|
symbolConstructor.valueDeclaration |
|
).getProperty(symbolName); |
|
const knownSymbolType = knownSymbol && typeChecker.getTypeOfSymbolAtLocation( |
|
knownSymbol, |
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-unsafe-member-access |
|
knownSymbol.valueDeclaration |
|
); |
|
if (knownSymbolType && isUniqueESSymbolType(knownSymbolType)) { |
|
return knownSymbolType.escapedName; |
|
} |
|
return "__@" + symbolName; |
|
} |
|
|
|
// src/types/utilities.ts |
|
import ts18 from "typescript"; |
|
|
|
// src/nodes/utilities.ts |
|
import ts17 from "typescript"; |
|
function isBindableObjectDefinePropertyCall(node) { |
|
return node.arguments.length === 3 && isEntityNameExpression(node.arguments[0]) && isNumericOrStringLikeLiteral(node.arguments[1]) && ts17.isPropertyAccessExpression(node.expression) && node.expression.name.escapedText === "defineProperty" && ts17.isIdentifier(node.expression.expression) && node.expression.expression.escapedText === "Object"; |
|
} |
|
function isInConstContext(node) { |
|
let current = node; |
|
while (true) { |
|
const parent = current.parent; |
|
outer: |
|
switch (parent.kind) { |
|
case ts17.SyntaxKind.TypeAssertionExpression: |
|
case ts17.SyntaxKind.AsExpression: |
|
return isConstAssertionExpression(parent); |
|
case ts17.SyntaxKind.PrefixUnaryExpression: |
|
if (current.kind !== ts17.SyntaxKind.NumericLiteral) { |
|
return false; |
|
} |
|
switch (parent.operator) { |
|
case ts17.SyntaxKind.PlusToken: |
|
case ts17.SyntaxKind.MinusToken: |
|
current = parent; |
|
break outer; |
|
default: |
|
return false; |
|
} |
|
case ts17.SyntaxKind.PropertyAssignment: |
|
if (parent.initializer !== current) { |
|
return false; |
|
} |
|
current = parent.parent; |
|
break; |
|
case ts17.SyntaxKind.ShorthandPropertyAssignment: |
|
current = parent.parent; |
|
break; |
|
case ts17.SyntaxKind.ParenthesizedExpression: |
|
case ts17.SyntaxKind.ArrayLiteralExpression: |
|
case ts17.SyntaxKind.ObjectLiteralExpression: |
|
case ts17.SyntaxKind.TemplateExpression: |
|
current = parent; |
|
break; |
|
default: |
|
return false; |
|
} |
|
} |
|
} |
|
|
|
// src/types/utilities.ts |
|
function isFalsyType(type) { |
|
if (isTypeFlagSet( |
|
type, |
|
ts18.TypeFlags.Undefined | ts18.TypeFlags.Null | ts18.TypeFlags.Void |
|
)) { |
|
return true; |
|
} |
|
if (type.isLiteral()) { |
|
return !type.value; |
|
} |
|
return isFalseLiteralType(type); |
|
} |
|
function intersectionTypeParts(type) { |
|
return isIntersectionType(type) ? type.types : [type]; |
|
} |
|
function typeParts(type) { |
|
return isIntersectionType(type) || isUnionType(type) ? type.types : [type]; |
|
} |
|
function isReadonlyPropertyIntersection(type, name, typeChecker) { |
|
const typeParts2 = isIntersectionType(type) ? type.types : [type]; |
|
return typeParts2.some((subType) => { |
|
const prop = getPropertyOfType(subType, name); |
|
if (prop === void 0) { |
|
return false; |
|
} |
|
if (prop.flags & ts18.SymbolFlags.Transient) { |
|
if (/^(?:[1-9]\d*|0)$/.test(name) && isTupleTypeReference(subType)) { |
|
return subType.target.readonly; |
|
} |
|
switch (isReadonlyPropertyFromMappedType(subType, name, typeChecker)) { |
|
case true: |
|
return true; |
|
case false: |
|
return false; |
|
default: |
|
} |
|
} |
|
return !!// members of namespace import |
|
(isSymbolFlagSet(prop, ts18.SymbolFlags.ValueModule) || // we unwrapped every mapped type, now we can check the actual declarations |
|
symbolHasReadonlyDeclaration(prop, typeChecker)); |
|
}); |
|
} |
|
function isReadonlyPropertyFromMappedType(type, name, typeChecker) { |
|
if (!isObjectType(type) || !isObjectFlagSet(type, ts18.ObjectFlags.Mapped)) { |
|
return; |
|
} |
|
const declaration = type.symbol.declarations[0]; |
|
if (declaration.readonlyToken !== void 0 && !/^__@[^@]+$/.test(name)) { |
|
return declaration.readonlyToken.kind !== ts18.SyntaxKind.MinusToken; |
|
} |
|
const { modifiersType } = type; |
|
return modifiersType && isPropertyReadonlyInType(modifiersType, name, typeChecker); |
|
} |
|
function isCallback(typeChecker, param, node) { |
|
let type = typeChecker.getApparentType( |
|
typeChecker.getTypeOfSymbolAtLocation(param, node) |
|
); |
|
if (param.valueDeclaration.dotDotDotToken) { |
|
type = type.getNumberIndexType(); |
|
if (type === void 0) { |
|
return false; |
|
} |
|
} |
|
for (const subType of unionTypeParts(type)) { |
|
if (subType.getCallSignatures().length !== 0) { |
|
return true; |
|
} |
|
} |
|
return false; |
|
} |
|
function isPropertyReadonlyInType(type, name, typeChecker) { |
|
let seenProperty = false; |
|
let seenReadonlySignature = false; |
|
for (const subType of unionTypeParts(type)) { |
|
if (getPropertyOfType(subType, name) === void 0) { |
|
const index = (isNumericPropertyName(name) ? typeChecker.getIndexInfoOfType(subType, ts18.IndexKind.Number) : void 0) ?? typeChecker.getIndexInfoOfType(subType, ts18.IndexKind.String); |
|
if (index?.isReadonly) { |
|
if (seenProperty) { |
|
return true; |
|
} |
|
seenReadonlySignature = true; |
|
} |
|
} else if (seenReadonlySignature || isReadonlyPropertyIntersection(subType, name, typeChecker)) { |
|
return true; |
|
} else { |
|
seenProperty = true; |
|
} |
|
} |
|
return false; |
|
} |
|
function isReadonlyAssignmentDeclaration(node, typeChecker) { |
|
if (!isBindableObjectDefinePropertyCall(node)) { |
|
return false; |
|
} |
|
const descriptorType = typeChecker.getTypeAtLocation(node.arguments[2]); |
|
if (descriptorType.getProperty("value") === void 0) { |
|
return descriptorType.getProperty("set") === void 0; |
|
} |
|
const writableProp = descriptorType.getProperty("writable"); |
|
if (writableProp === void 0) { |
|
return false; |
|
} |
|
const writableType = writableProp.valueDeclaration !== void 0 && ts18.isPropertyAssignment(writableProp.valueDeclaration) ? typeChecker.getTypeAtLocation(writableProp.valueDeclaration.initializer) : typeChecker.getTypeOfSymbolAtLocation(writableProp, node.arguments[2]); |
|
return isFalseLiteralType(writableType); |
|
} |
|
function isThenableType(typeChecker, node, type = typeChecker.getTypeAtLocation(node)) { |
|
for (const typePart of unionTypeParts(typeChecker.getApparentType(type))) { |
|
const then = typePart.getProperty("then"); |
|
if (then === void 0) { |
|
continue; |
|
} |
|
const thenType = typeChecker.getTypeOfSymbolAtLocation(then, node); |
|
for (const subTypePart of unionTypeParts(thenType)) { |
|
for (const signature of subTypePart.getCallSignatures()) { |
|
if (signature.parameters.length !== 0 && isCallback(typeChecker, signature.parameters[0], node)) { |
|
return true; |
|
} |
|
} |
|
} |
|
} |
|
return false; |
|
} |
|
function symbolHasReadonlyDeclaration(symbol, typeChecker) { |
|
return !!((symbol.flags & ts18.SymbolFlags.Accessor) === ts18.SymbolFlags.GetAccessor || symbol.declarations?.some( |
|
(node) => isModifierFlagSet(node, ts18.ModifierFlags.Readonly) || ts18.isVariableDeclaration(node) && isNodeFlagSet(node.parent, ts18.NodeFlags.Const) || ts18.isCallExpression(node) && isReadonlyAssignmentDeclaration(node, typeChecker) || ts18.isEnumMember(node) || (ts18.isPropertyAssignment(node) || ts18.isShorthandPropertyAssignment(node)) && isInConstContext(node.parent) |
|
)); |
|
} |
|
function unionTypeParts(type) { |
|
return isUnionType(type) ? type.types : [type]; |
|
} |
|
|
|
// src/usage/UsageWalker.ts |
|
import ts24 from "typescript"; |
|
|
|
// src/usage/Scope.ts |
|
import ts19 from "typescript"; |
|
function isBlockScopeBoundary(node) { |
|
switch (node.kind) { |
|
case ts19.SyntaxKind.Block: { |
|
const parent = node.parent; |
|
return parent.kind !== ts19.SyntaxKind.CatchClause && // blocks inside SourceFile are block scope boundaries |
|
(parent.kind === ts19.SyntaxKind.SourceFile || // blocks that are direct children of a function scope boundary are no scope boundary |
|
// for example the FunctionBlock is part of the function scope of the containing function |
|
!isFunctionScopeBoundary(parent)) ? 2 /* Block */ : 0 /* None */; |
|
} |
|
case ts19.SyntaxKind.ForStatement: |
|
case ts19.SyntaxKind.ForInStatement: |
|
case ts19.SyntaxKind.ForOfStatement: |
|
case ts19.SyntaxKind.CaseBlock: |
|
case ts19.SyntaxKind.CatchClause: |
|
case ts19.SyntaxKind.WithStatement: |
|
return 2 /* Block */; |
|
default: |
|
return 0 /* None */; |
|
} |
|
} |
|
|
|
// src/usage/declarations.ts |
|
import ts21 from "typescript"; |
|
|
|
// src/usage/utils.ts |
|
import ts20 from "typescript"; |
|
function identifierToKeywordKind(node) { |
|
return "identifierToKeywordKind" in ts20 ? ts20.identifierToKeywordKind(node) : ( |
|
// eslint-disable-next-line deprecation/deprecation |
|
node.originalKeywordKind |
|
); |
|
} |
|
function canHaveDecorators(node) { |
|
return "canHaveDecorators" in ts20 ? ts20.canHaveDecorators(node) : "decorators" in node; |
|
} |
|
function getDecorators(node) { |
|
return "getDecorators" in ts20 ? ts20.getDecorators(node) : node.decorators; |
|
} |
|
|
|
// src/usage/declarations.ts |
|
var DeclarationDomain = /* @__PURE__ */ ((DeclarationDomain2) => { |
|
DeclarationDomain2[DeclarationDomain2["Import"] = 8] = "Import"; |
|
DeclarationDomain2[DeclarationDomain2["Namespace"] = 1] = "Namespace"; |
|
DeclarationDomain2[DeclarationDomain2["Type"] = 2] = "Type"; |
|
DeclarationDomain2[DeclarationDomain2["Value"] = 4] = "Value"; |
|
DeclarationDomain2[DeclarationDomain2["Any"] = 7] = "Any"; |
|
return DeclarationDomain2; |
|
})(DeclarationDomain || {}); |
|
function getDeclarationDomain(node) { |
|
switch (node.parent.kind) { |
|
case ts21.SyntaxKind.TypeParameter: |
|
case ts21.SyntaxKind.InterfaceDeclaration: |
|
case ts21.SyntaxKind.TypeAliasDeclaration: |
|
return 2 /* Type */; |
|
case ts21.SyntaxKind.ClassDeclaration: |
|
case ts21.SyntaxKind.ClassExpression: |
|
return 2 /* Type */ | 4 /* Value */; |
|
case ts21.SyntaxKind.EnumDeclaration: |
|
return 7 /* Any */; |
|
case ts21.SyntaxKind.NamespaceImport: |
|
case ts21.SyntaxKind.ImportClause: |
|
return 7 /* Any */ | 8 /* Import */; |
|
case ts21.SyntaxKind.ImportEqualsDeclaration: |
|
case ts21.SyntaxKind.ImportSpecifier: |
|
return node.parent.name === node ? 7 /* Any */ | 8 /* Import */ : void 0; |
|
case ts21.SyntaxKind.ModuleDeclaration: |
|
return 1 /* Namespace */; |
|
case ts21.SyntaxKind.Parameter: |
|
if (node.parent.parent.kind === ts21.SyntaxKind.IndexSignature || identifierToKeywordKind(node) === ts21.SyntaxKind.ThisKeyword) { |
|
return; |
|
} |
|
case ts21.SyntaxKind.BindingElement: |
|
case ts21.SyntaxKind.VariableDeclaration: |
|
return node.parent.name === node ? 4 /* Value */ : void 0; |
|
case ts21.SyntaxKind.FunctionDeclaration: |
|
case ts21.SyntaxKind.FunctionExpression: |
|
return 4 /* Value */; |
|
} |
|
} |
|
|
|
// src/usage/getPropertyName.ts |
|
import ts22 from "typescript"; |
|
function unwrapParentheses(node) { |
|
while (node.kind === ts22.SyntaxKind.ParenthesizedExpression) { |
|
node = node.expression; |
|
} |
|
return node; |
|
} |
|
function getPropertyName(propertyName) { |
|
if (propertyName.kind === ts22.SyntaxKind.ComputedPropertyName) { |
|
const expression = unwrapParentheses(propertyName.expression); |
|
if (ts22.isPrefixUnaryExpression(expression)) { |
|
let negate = false; |
|
switch (expression.operator) { |
|
case ts22.SyntaxKind.MinusToken: |
|
negate = true; |
|
case ts22.SyntaxKind.PlusToken: |
|
return ts22.isNumericLiteral(expression.operand) ? `${negate ? "-" : ""}${expression.operand.text}` : ts22.isBigIntLiteral(expression.operand) ? `${negate ? "-" : ""}${expression.operand.text.slice(0, -1)}` : void 0; |
|
default: |
|
return; |
|
} |
|
} |
|
if (ts22.isBigIntLiteral(expression)) { |
|
return expression.text.slice(0, -1); |
|
} |
|
if (isNumericOrStringLikeLiteral(expression)) { |
|
return expression.text; |
|
} |
|
return; |
|
} |
|
return propertyName.kind === ts22.SyntaxKind.PrivateIdentifier ? void 0 : propertyName.text; |
|
} |
|
|
|
// src/usage/getUsageDomain.ts |
|
import ts23 from "typescript"; |
|
var UsageDomain = /* @__PURE__ */ ((UsageDomain2) => { |
|
UsageDomain2[UsageDomain2["Namespace"] = 1] = "Namespace"; |
|
UsageDomain2[UsageDomain2["Type"] = 2] = "Type"; |
|
UsageDomain2[UsageDomain2["TypeQuery"] = 8] = "TypeQuery"; |
|
UsageDomain2[UsageDomain2["Value"] = 4] = "Value"; |
|
UsageDomain2[UsageDomain2["ValueOrNamespace"] = 5] = "ValueOrNamespace"; |
|
UsageDomain2[UsageDomain2["Any"] = 7] = "Any"; |
|
return UsageDomain2; |
|
})(UsageDomain || {}); |
|
function getUsageDomain(node) { |
|
const parent = node.parent; |
|
switch (parent.kind) { |
|
case ts23.SyntaxKind.TypeReference: |
|
return identifierToKeywordKind(node) !== ts23.SyntaxKind.ConstKeyword ? 2 /* Type */ : void 0; |
|
case ts23.SyntaxKind.ExpressionWithTypeArguments: |
|
return parent.parent.token === ts23.SyntaxKind.ImplementsKeyword || parent.parent.parent.kind === ts23.SyntaxKind.InterfaceDeclaration ? 2 /* Type */ : 4 /* Value */; |
|
case ts23.SyntaxKind.TypeQuery: |
|
return 5 /* ValueOrNamespace */ | 8 /* TypeQuery */; |
|
case ts23.SyntaxKind.QualifiedName: |
|
if (parent.left === node) { |
|
if (getEntityNameParent(parent).kind === ts23.SyntaxKind.TypeQuery) { |
|
return 1 /* Namespace */ | 8 /* TypeQuery */; |
|
} |
|
return 1 /* Namespace */; |
|
} |
|
break; |
|
case ts23.SyntaxKind.ExportSpecifier: |
|
if (parent.propertyName === void 0 || parent.propertyName === node) { |
|
return 7 /* Any */; |
|
} |
|
break; |
|
case ts23.SyntaxKind.ExportAssignment: |
|
return 7 /* Any */; |
|
case ts23.SyntaxKind.BindingElement: |
|
if (parent.initializer === node) { |
|
return 5 /* ValueOrNamespace */; |
|
} |
|
break; |
|
case ts23.SyntaxKind.Parameter: |
|
case ts23.SyntaxKind.EnumMember: |
|
case ts23.SyntaxKind.PropertyDeclaration: |
|
case ts23.SyntaxKind.VariableDeclaration: |
|
case ts23.SyntaxKind.PropertyAssignment: |
|
case ts23.SyntaxKind.PropertyAccessExpression: |
|
case ts23.SyntaxKind.ImportEqualsDeclaration: |
|
if (parent.name !== node) { |
|
return 5 /* ValueOrNamespace */; |
|
} |
|
break; |
|
case ts23.SyntaxKind.JsxAttribute: |
|
case ts23.SyntaxKind.FunctionDeclaration: |
|
case ts23.SyntaxKind.FunctionExpression: |
|
case ts23.SyntaxKind.NamespaceImport: |
|
case ts23.SyntaxKind.ClassDeclaration: |
|
case ts23.SyntaxKind.ClassExpression: |
|
case ts23.SyntaxKind.ModuleDeclaration: |
|
case ts23.SyntaxKind.MethodDeclaration: |
|
case ts23.SyntaxKind.EnumDeclaration: |
|
case ts23.SyntaxKind.GetAccessor: |
|
case ts23.SyntaxKind.SetAccessor: |
|
case ts23.SyntaxKind.LabeledStatement: |
|
case ts23.SyntaxKind.BreakStatement: |
|
case ts23.SyntaxKind.ContinueStatement: |
|
case ts23.SyntaxKind.ImportClause: |
|
case ts23.SyntaxKind.ImportSpecifier: |
|
case ts23.SyntaxKind.TypePredicate: |
|
case ts23.SyntaxKind.MethodSignature: |
|
case ts23.SyntaxKind.PropertySignature: |
|
case ts23.SyntaxKind.NamespaceExportDeclaration: |
|
case ts23.SyntaxKind.NamespaceExport: |
|
case ts23.SyntaxKind.InterfaceDeclaration: |
|
case ts23.SyntaxKind.TypeAliasDeclaration: |
|
case ts23.SyntaxKind.TypeParameter: |
|
case ts23.SyntaxKind.NamedTupleMember: |
|
break; |
|
default: |
|
return 5 /* ValueOrNamespace */; |
|
} |
|
} |
|
function getEntityNameParent(name) { |
|
let parent = name.parent; |
|
while (parent.kind === ts23.SyntaxKind.QualifiedName) { |
|
parent = parent.parent; |
|
} |
|
return parent; |
|
} |
|
|
|
// src/usage/scopes.ts |
|
var _enumScopes; |
|
var AbstractScope = class { |
|
constructor(global) { |
|
this.global = global; |
|
__privateAdd(this, _enumScopes, void 0); |
|
this.namespaceScopes = void 0; |
|
this.uses = []; |
|
this.variables = /* @__PURE__ */ new Map(); |
|
} |
|
addUse(use) { |
|
this.uses.push(use); |
|
} |
|
// eslint-disable-next-line @typescript-eslint/no-empty-function |
|
addUseToParent(_use) { |
|
} |
|
addVariable(identifier, name, selector, exported, domain) { |
|
const variables = this.getDestinationScope(selector).getVariables(); |
|
const declaration = { |
|
declaration: name, |
|
domain, |
|
exported |
|
}; |
|
const variable = variables.get(identifier); |
|
if (variable === void 0) { |
|
variables.set(identifier, { |
|
declarations: [declaration], |
|
domain, |
|
uses: [] |
|
}); |
|
} else { |
|
variable.domain |= domain; |
|
variable.declarations.push(declaration); |
|
} |
|
} |
|
applyUse(use, variables = this.variables) { |
|
const variable = variables.get(use.location.text); |
|
if (variable === void 0 || (variable.domain & use.domain) === 0) { |
|
return false; |
|
} |
|
variable.uses.push(use); |
|
return true; |
|
} |
|
applyUses() { |
|
for (const use of this.uses) { |
|
if (!this.applyUse(use)) { |
|
this.addUseToParent(use); |
|
} |
|
} |
|
this.uses = []; |
|
} |
|
createOrReuseEnumScope(name, _exported) { |
|
let scope; |
|
if (__privateGet(this, _enumScopes) === void 0) { |
|
__privateSet(this, _enumScopes, /* @__PURE__ */ new Map()); |
|
} else { |
|
scope = __privateGet(this, _enumScopes).get(name); |
|
} |
|
if (scope === void 0) { |
|
scope = new EnumScope(this); |
|
__privateGet(this, _enumScopes).set(name, scope); |
|
} |
|
return scope; |
|
} |
|
// only relevant for the root scope |
|
createOrReuseNamespaceScope(name, _exported, ambient, hasExportStatement) { |
|
let scope; |
|
if (this.namespaceScopes === void 0) { |
|
this.namespaceScopes = /* @__PURE__ */ new Map(); |
|
} else { |
|
scope = this.namespaceScopes.get(name); |
|
} |
|
if (scope === void 0) { |
|
scope = new NamespaceScope(ambient, hasExportStatement, this); |
|
this.namespaceScopes.set(name, scope); |
|
} else { |
|
scope.refresh(ambient, hasExportStatement); |
|
} |
|
return scope; |
|
} |
|
end(cb) { |
|
if (this.namespaceScopes !== void 0) { |
|
this.namespaceScopes.forEach((value) => value.finish(cb)); |
|
} |
|
this.namespaceScopes = __privateSet(this, _enumScopes, void 0); |
|
this.applyUses(); |
|
this.variables.forEach((variable) => { |
|
for (const declaration of variable.declarations) { |
|
const result = { |
|
declarations: [], |
|
domain: declaration.domain, |
|
exported: declaration.exported, |
|
inGlobalScope: this.global, |
|
uses: [] |
|
}; |
|
for (const other of variable.declarations) { |
|
if (other.domain & declaration.domain) { |
|
result.declarations.push(other.declaration); |
|
} |
|
} |
|
for (const use of variable.uses) { |
|
if (use.domain & declaration.domain) { |
|
result.uses.push(use); |
|
} |
|
} |
|
cb(result, declaration.declaration, this); |
|
} |
|
}); |
|
} |
|
getFunctionScope() { |
|
return this; |
|
} |
|
getVariables() { |
|
return this.variables; |
|
} |
|
// eslint-disable-next-line @typescript-eslint/no-empty-function |
|
markExported(_name2) { |
|
} |
|
}; |
|
_enumScopes = new WeakMap(); |
|
var NonRootScope = class extends AbstractScope { |
|
constructor(parent, boundary) { |
|
super(false); |
|
this.parent = parent; |
|
this.boundary = boundary; |
|
} |
|
addUseToParent(use) { |
|
return this.parent.addUse(use, this); |
|
} |
|
getDestinationScope(selector) { |
|
return this.boundary & selector ? this : this.parent.getDestinationScope(selector); |
|
} |
|
}; |
|
var EnumScope = class extends NonRootScope { |
|
constructor(parent) { |
|
super(parent, 1 /* Function */); |
|
} |
|
end() { |
|
this.applyUses(); |
|
} |
|
}; |
|
var _exportAll, _exports, _innerScope; |
|
var RootScope = class extends AbstractScope { |
|
constructor(exportAll, global) { |
|
super(global); |
|
__privateAdd(this, _exportAll, void 0); |
|
__privateAdd(this, _exports, void 0); |
|
__privateAdd(this, _innerScope, new NonRootScope(this, 1 /* Function */)); |
|
__privateSet(this, _exportAll, exportAll); |
|
} |
|
addUse(use, origin) { |
|
if (origin === __privateGet(this, _innerScope)) { |
|
return super.addUse(use); |
|
} |
|
return __privateGet(this, _innerScope).addUse(use); |
|
} |
|
addVariable(identifier, name, selector, exported, domain) { |
|
if (domain & 8 /* Import */) { |
|
return super.addVariable(identifier, name, selector, exported, domain); |
|
} |
|
return __privateGet(this, _innerScope).addVariable( |
|
identifier, |
|
name, |
|
selector, |
|
exported, |
|
domain |
|
); |
|
} |
|
end(cb) { |
|
__privateGet(this, _innerScope).end((value, key) => { |
|
value.exported ||= __privateGet(this, _exportAll) || __privateGet(this, _exports) !== void 0 && __privateGet(this, _exports).includes(key.text); |
|
value.inGlobalScope = this.global; |
|
return cb(value, key, this); |
|
}); |
|
return super.end((value, key, scope) => { |
|
value.exported ||= scope === this && __privateGet(this, _exports) !== void 0 && __privateGet(this, _exports).includes(key.text); |
|
return cb(value, key, scope); |
|
}); |
|
} |
|
getDestinationScope() { |
|
return this; |
|
} |
|
markExported(id) { |
|
if (__privateGet(this, _exports) === void 0) { |
|
__privateSet(this, _exports, [id.text]); |
|
} else { |
|
__privateGet(this, _exports).push(id.text); |
|
} |
|
} |
|
}; |
|
_exportAll = new WeakMap(); |
|
_exports = new WeakMap(); |
|
_innerScope = new WeakMap(); |
|
var _ambient, _exports2, _hasExport, _innerScope2; |
|
var NamespaceScope = class extends NonRootScope { |
|
constructor(ambient, hasExport, parent) { |
|
super(parent, 1 /* Function */); |
|
__privateAdd(this, _ambient, void 0); |
|
__privateAdd(this, _exports2, void 0); |
|
__privateAdd(this, _hasExport, void 0); |
|
__privateAdd(this, _innerScope2, new NonRootScope(this, 1 /* Function */)); |
|
__privateSet(this, _ambient, ambient); |
|
__privateSet(this, _hasExport, hasExport); |
|
} |
|
addUse(use, source) { |
|
if (source !== __privateGet(this, _innerScope2)) { |
|
return __privateGet(this, _innerScope2).addUse(use); |
|
} |
|
this.uses.push(use); |
|
} |
|
createOrReuseEnumScope(name, exported) { |
|
if (!exported && (!__privateGet(this, _ambient) || __privateGet(this, _hasExport))) { |
|
return __privateGet(this, _innerScope2).createOrReuseEnumScope(name, exported); |
|
} |
|
return super.createOrReuseEnumScope(name, exported); |
|
} |
|
createOrReuseNamespaceScope(name, exported, ambient, hasExportStatement) { |
|
if (!exported && (!__privateGet(this, _ambient) || __privateGet(this, _hasExport))) { |
|
return __privateGet(this, _innerScope2).createOrReuseNamespaceScope( |
|
name, |
|
exported, |
|
ambient || __privateGet(this, _ambient), |
|
hasExportStatement |
|
); |
|
} |
|
return super.createOrReuseNamespaceScope( |
|
name, |
|
exported, |
|
ambient || __privateGet(this, _ambient), |
|
hasExportStatement |
|
); |
|
} |
|
end(cb) { |
|
__privateGet(this, _innerScope2).end((variable, key, scope) => { |
|
if (scope !== __privateGet(this, _innerScope2) || !variable.exported && (!__privateGet(this, _ambient) || __privateGet(this, _exports2) !== void 0 && !__privateGet(this, _exports2).has(key.text))) { |
|
return cb(variable, key, scope); |
|
} |
|
const namespaceVar = this.variables.get(key.text); |
|
if (namespaceVar === void 0) { |
|
this.variables.set(key.text, { |
|
declarations: variable.declarations.map(mapDeclaration), |
|
domain: variable.domain, |
|
uses: [...variable.uses] |
|
}); |
|
} else { |
|
outer: |
|
for (const declaration of variable.declarations) { |
|
for (const existing of namespaceVar.declarations) { |
|
if (existing.declaration === declaration) { |
|
continue outer; |
|
} |
|
namespaceVar.declarations.push(mapDeclaration(declaration)); |
|
} |
|
} |
|
namespaceVar.domain |= variable.domain; |
|
for (const use of variable.uses) { |
|
if (namespaceVar.uses.includes(use)) { |
|
continue; |
|
} |
|
namespaceVar.uses.push(use); |
|
} |
|
} |
|
}); |
|
this.applyUses(); |
|
__privateSet(this, _innerScope2, new NonRootScope(this, 1 /* Function */)); |
|
} |
|
finish(cb) { |
|
return super.end(cb); |
|
} |
|
getDestinationScope() { |
|
return __privateGet(this, _innerScope2); |
|
} |
|
markExported(name) { |
|
if (__privateGet(this, _exports2) === void 0) { |
|
__privateSet(this, _exports2, /* @__PURE__ */ new Set()); |
|
} |
|
__privateGet(this, _exports2).add(name.text); |
|
} |
|
refresh(ambient, hasExport) { |
|
__privateSet(this, _ambient, ambient); |
|
__privateSet(this, _hasExport, hasExport); |
|
} |
|
}; |
|
_ambient = new WeakMap(); |
|
_exports2 = new WeakMap(); |
|
_hasExport = new WeakMap(); |
|
_innerScope2 = new WeakMap(); |
|
function mapDeclaration(declaration) { |
|
return { |
|
declaration, |
|
domain: getDeclarationDomain(declaration), |
|
exported: true |
|
}; |
|
} |
|
var FunctionScope = class extends NonRootScope { |
|
constructor(parent) { |
|
super(parent, 1 /* Function */); |
|
} |
|
beginBody() { |
|
this.applyUses(); |
|
} |
|
}; |
|
var _domain, _name; |
|
var AbstractNamedExpressionScope = class extends NonRootScope { |
|
constructor(name, domain, parent) { |
|
super(parent, 1 /* Function */); |
|
__privateAdd(this, _domain, void 0); |
|
__privateAdd(this, _name, void 0); |
|
__privateSet(this, _name, name); |
|
__privateSet(this, _domain, domain); |
|
} |
|
addUse(use, source) { |
|
if (source !== this.innerScope) { |
|
return this.innerScope.addUse(use); |
|
} |
|
if (use.domain & __privateGet(this, _domain) && use.location.text === __privateGet(this, _name).text) { |
|
this.uses.push(use); |
|
} else { |
|
return this.parent.addUse(use, this); |
|
} |
|
} |
|
end(cb) { |
|
this.innerScope.end(cb); |
|
return cb( |
|
{ |
|
declarations: [__privateGet(this, _name)], |
|
domain: __privateGet(this, _domain), |
|
exported: false, |
|
inGlobalScope: false, |
|
uses: this.uses |
|
}, |
|
__privateGet(this, _name), |
|
this |
|
); |
|
} |
|
getDestinationScope() { |
|
return this.innerScope; |
|
} |
|
getFunctionScope() { |
|
return this.innerScope; |
|
} |
|
}; |
|
_domain = new WeakMap(); |
|
_name = new WeakMap(); |
|
var FunctionExpressionScope = class extends AbstractNamedExpressionScope { |
|
constructor(name, parent) { |
|
super(name, 4 /* Value */, parent); |
|
this.innerScope = new FunctionScope(this); |
|
} |
|
beginBody() { |
|
return this.innerScope.beginBody(); |
|
} |
|
}; |
|
var _functionScope; |
|
var BlockScope = class extends NonRootScope { |
|
constructor(functionScope, parent) { |
|
super(parent, 2 /* Block */); |
|
__privateAdd(this, _functionScope, void 0); |
|
__privateSet(this, _functionScope, functionScope); |
|
} |
|
getFunctionScope() { |
|
return __privateGet(this, _functionScope); |
|
} |
|
}; |
|
_functionScope = new WeakMap(); |
|
var ClassExpressionScope = class extends AbstractNamedExpressionScope { |
|
constructor(name, parent) { |
|
super(name, 4 /* Value */ | 2 /* Type */, parent); |
|
this.innerScope = new NonRootScope(this, 1 /* Function */); |
|
} |
|
}; |
|
var _state; |
|
var ConditionalTypeScope = class extends NonRootScope { |
|
constructor(parent) { |
|
super(parent, 8 /* ConditionalType */); |
|
__privateAdd(this, _state, 0 /* Initial */); |
|
} |
|
addUse(use) { |
|
if (__privateGet(this, _state) === 2 /* TrueType */) { |
|
return void this.uses.push(use); |
|
} |
|
return this.parent.addUse(use, this); |
|
} |
|
updateState(newState) { |
|
__privateSet(this, _state, newState); |
|
} |
|
}; |
|
_state = new WeakMap(); |
|
|
|
// src/usage/UsageWalker.ts |
|
var _result, _scope, _handleBindingName, handleBindingName_fn, _handleConditionalType, handleConditionalType_fn, _handleDeclaration, handleDeclaration_fn, _handleFunctionLikeDeclaration, handleFunctionLikeDeclaration_fn, _handleModule, handleModule_fn, _handleVariableDeclaration, handleVariableDeclaration_fn; |
|
var UsageWalker = class { |
|
constructor() { |
|
__privateAdd(this, _handleBindingName); |
|
__privateAdd(this, _handleConditionalType); |
|
__privateAdd(this, _handleDeclaration); |
|
__privateAdd(this, _handleFunctionLikeDeclaration); |
|
__privateAdd(this, _handleModule); |
|
__privateAdd(this, _handleVariableDeclaration); |
|
__privateAdd(this, _result, /* @__PURE__ */ new Map()); |
|
__privateAdd(this, _scope, void 0); |
|
} |
|
getUsage(sourceFile) { |
|
const variableCallback = (variable, key) => { |
|
__privateGet(this, _result).set(key, variable); |
|
}; |
|
const isModule = ts24.isExternalModule(sourceFile); |
|
__privateSet(this, _scope, new RootScope( |
|
sourceFile.isDeclarationFile && isModule && !containsExportStatement(sourceFile), |
|
!isModule |
|
)); |
|
const cb = (node) => { |
|
if (isBlockScopeBoundary(node)) { |
|
return continueWithScope( |
|
node, |
|
new BlockScope(__privateGet(this, _scope).getFunctionScope(), __privateGet(this, _scope)), |
|
handleBlockScope |
|
); |
|
} |
|
switch (node.kind) { |
|
case ts24.SyntaxKind.ClassExpression: |
|
return continueWithScope( |
|
node, |
|
node.name !== void 0 ? new ClassExpressionScope( |
|
node.name, |
|
__privateGet(this, _scope) |
|
) : new NonRootScope(__privateGet(this, _scope), 1 /* Function */) |
|
); |
|
case ts24.SyntaxKind.ClassDeclaration: |
|
__privateMethod(this, _handleDeclaration, handleDeclaration_fn).call(this, node, true, 4 /* Value */ | 2 /* Type */); |
|
return continueWithScope( |
|
node, |
|
new NonRootScope(__privateGet(this, _scope), 1 /* Function */) |
|
); |
|
case ts24.SyntaxKind.InterfaceDeclaration: |
|
case ts24.SyntaxKind.TypeAliasDeclaration: |
|
__privateMethod(this, _handleDeclaration, handleDeclaration_fn).call(this, node, true, 2 /* Type */); |
|
return continueWithScope( |
|
node, |
|
new NonRootScope(__privateGet(this, _scope), 4 /* Type */) |
|
); |
|
case ts24.SyntaxKind.EnumDeclaration: |
|
__privateMethod(this, _handleDeclaration, handleDeclaration_fn).call(this, node, true, 7 /* Any */); |
|
return continueWithScope( |
|
node, |
|
__privateGet(this, _scope).createOrReuseEnumScope( |
|
node.name.text, |
|
includesModifier( |
|
node.modifiers, |
|
ts24.SyntaxKind.ExportKeyword |
|
) |
|
) |
|
); |
|
case ts24.SyntaxKind.ModuleDeclaration: |
|
return __privateMethod(this, _handleModule, handleModule_fn).call(this, node, continueWithScope); |
|
case ts24.SyntaxKind.MappedType: |
|
return continueWithScope( |
|
node, |
|
new NonRootScope(__privateGet(this, _scope), 4 /* Type */) |
|
); |
|
case ts24.SyntaxKind.FunctionExpression: |
|
case ts24.SyntaxKind.ArrowFunction: |
|
case ts24.SyntaxKind.Constructor: |
|
case ts24.SyntaxKind.MethodDeclaration: |
|
case ts24.SyntaxKind.FunctionDeclaration: |
|
case ts24.SyntaxKind.GetAccessor: |
|
case ts24.SyntaxKind.SetAccessor: |
|
case ts24.SyntaxKind.MethodSignature: |
|
case ts24.SyntaxKind.CallSignature: |
|
case ts24.SyntaxKind.ConstructSignature: |
|
case ts24.SyntaxKind.ConstructorType: |
|
case ts24.SyntaxKind.FunctionType: |
|
return __privateMethod(this, _handleFunctionLikeDeclaration, handleFunctionLikeDeclaration_fn).call(this, node, cb, variableCallback); |
|
case ts24.SyntaxKind.ConditionalType: |
|
return __privateMethod(this, _handleConditionalType, handleConditionalType_fn).call(this, node, cb, variableCallback); |
|
case ts24.SyntaxKind.VariableDeclarationList: |
|
__privateMethod(this, _handleVariableDeclaration, handleVariableDeclaration_fn).call(this, node); |
|
break; |
|
case ts24.SyntaxKind.Parameter: |
|
if (node.parent.kind !== ts24.SyntaxKind.IndexSignature && (node.name.kind !== ts24.SyntaxKind.Identifier || identifierToKeywordKind( |
|
node.name |
|
) !== ts24.SyntaxKind.ThisKeyword)) { |
|
__privateMethod(this, _handleBindingName, handleBindingName_fn).call(this, node.name, false, false); |
|
} |
|
break; |
|
case ts24.SyntaxKind.EnumMember: |
|
__privateGet(this, _scope).addVariable( |
|
getPropertyName(node.name), |
|
node.name, |
|
1 /* Function */, |
|
true, |
|
4 /* Value */ |
|
); |
|
break; |
|
case ts24.SyntaxKind.ImportClause: |
|
case ts24.SyntaxKind.ImportSpecifier: |
|
case ts24.SyntaxKind.NamespaceImport: |
|
case ts24.SyntaxKind.ImportEqualsDeclaration: |
|
__privateMethod(this, _handleDeclaration, handleDeclaration_fn).call(this, node, false, 7 /* Any */ | 8 /* Import */); |
|
break; |
|
case ts24.SyntaxKind.TypeParameter: |
|
__privateGet(this, _scope).addVariable( |
|
node.name.text, |
|
node.name, |
|
node.parent.kind === ts24.SyntaxKind.InferType ? 8 /* InferType */ : 7 /* Type */, |
|
false, |
|
2 /* Type */ |
|
); |
|
break; |
|
case ts24.SyntaxKind.ExportSpecifier: |
|
if (node.propertyName !== void 0) { |
|
return __privateGet(this, _scope).markExported( |
|
node.propertyName, |
|
node.name |
|
); |
|
} |
|
return __privateGet(this, _scope).markExported(node.name); |
|
case ts24.SyntaxKind.ExportAssignment: |
|
if (node.expression.kind === ts24.SyntaxKind.Identifier) { |
|
return __privateGet(this, _scope).markExported( |
|
node.expression |
|
); |
|
} |
|
break; |
|
case ts24.SyntaxKind.Identifier: { |
|
const domain = getUsageDomain(node); |
|
if (domain !== void 0) { |
|
__privateGet(this, _scope).addUse({ domain, location: node }); |
|
} |
|
return; |
|
} |
|
} |
|
return ts24.forEachChild(node, cb); |
|
}; |
|
const continueWithScope = (node, scope, next = forEachChild) => { |
|
const savedScope = __privateGet(this, _scope); |
|
__privateSet(this, _scope, scope); |
|
next(node); |
|
__privateGet(this, _scope).end(variableCallback); |
|
__privateSet(this, _scope, savedScope); |
|
}; |
|
const handleBlockScope = (node) => { |
|
if (node.kind === ts24.SyntaxKind.CatchClause && node.variableDeclaration !== void 0) { |
|
__privateMethod(this, _handleBindingName, handleBindingName_fn).call(this, node.variableDeclaration.name, true, false); |
|
} |
|
return ts24.forEachChild(node, cb); |
|
}; |
|
ts24.forEachChild(sourceFile, cb); |
|
__privateGet(this, _scope).end(variableCallback); |
|
return __privateGet(this, _result); |
|
function forEachChild(node) { |
|
return ts24.forEachChild(node, cb); |
|
} |
|
} |
|
}; |
|
_result = new WeakMap(); |
|
_scope = new WeakMap(); |
|
_handleBindingName = new WeakSet(); |
|
handleBindingName_fn = function(name, blockScoped, exported) { |
|
if (name.kind === ts24.SyntaxKind.Identifier) { |
|
return __privateGet(this, _scope).addVariable( |
|
name.text, |
|
name, |
|
blockScoped ? 3 /* Block */ : 1 /* Function */, |
|
exported, |
|
4 /* Value */ |
|
); |
|
} |
|
forEachDestructuringIdentifier(name, (declaration) => { |
|
__privateGet(this, _scope).addVariable( |
|
declaration.name.text, |
|
declaration.name, |
|
blockScoped ? 3 /* Block */ : 1 /* Function */, |
|
exported, |
|
4 /* Value */ |
|
); |
|
}); |
|
}; |
|
_handleConditionalType = new WeakSet(); |
|
handleConditionalType_fn = function(node, cb, varCb) { |
|
const savedScope = __privateGet(this, _scope); |
|
const scope = __privateSet(this, _scope, new ConditionalTypeScope(savedScope)); |
|
cb(node.checkType); |
|
scope.updateState(1 /* Extends */); |
|
cb(node.extendsType); |
|
scope.updateState(2 /* TrueType */); |
|
cb(node.trueType); |
|
scope.updateState(3 /* FalseType */); |
|
cb(node.falseType); |
|
scope.end(varCb); |
|
__privateSet(this, _scope, savedScope); |
|
}; |
|
_handleDeclaration = new WeakSet(); |
|
handleDeclaration_fn = function(node, blockScoped, domain) { |
|
if (node.name !== void 0) { |
|
__privateGet(this, _scope).addVariable( |
|
node.name.text, |
|
node.name, |
|
blockScoped ? 3 /* Block */ : 1 /* Function */, |
|
includesModifier( |
|
node.modifiers, |
|
ts24.SyntaxKind.ExportKeyword |
|
), |
|
domain |
|
); |
|
} |
|
}; |
|
_handleFunctionLikeDeclaration = new WeakSet(); |
|
handleFunctionLikeDeclaration_fn = function(node, cb, varCb) { |
|
if (canHaveDecorators(node)) { |
|
getDecorators(node)?.forEach(cb); |
|
} |
|
const savedScope = __privateGet(this, _scope); |
|
if (node.kind === ts24.SyntaxKind.FunctionDeclaration) { |
|
__privateMethod(this, _handleDeclaration, handleDeclaration_fn).call(this, node, false, 4 /* Value */); |
|
} |
|
const scope = __privateSet(this, _scope, node.kind === ts24.SyntaxKind.FunctionExpression && node.name !== void 0 ? new FunctionExpressionScope(node.name, savedScope) : new FunctionScope(savedScope)); |
|
if (node.name !== void 0) { |
|
cb(node.name); |
|
} |
|
if (node.typeParameters !== void 0) { |
|
node.typeParameters.forEach(cb); |
|
} |
|
node.parameters.forEach(cb); |
|
if (node.type !== void 0) { |
|
cb(node.type); |
|
} |
|
if (node.body !== void 0) { |
|
scope.beginBody(); |
|
cb(node.body); |
|
} |
|
scope.end(varCb); |
|
__privateSet(this, _scope, savedScope); |
|
}; |
|
_handleModule = new WeakSet(); |
|
handleModule_fn = function(node, next) { |
|
if (node.flags & ts24.NodeFlags.GlobalAugmentation) { |
|
return next( |
|
node, |
|
__privateGet(this, _scope).createOrReuseNamespaceScope("-global", false, true, false) |
|
); |
|
} |
|
if (node.name.kind === ts24.SyntaxKind.Identifier) { |
|
const exported = isNamespaceExported(node); |
|
__privateGet(this, _scope).addVariable( |
|
node.name.text, |
|
node.name, |
|
1 /* Function */, |
|
exported, |
|
1 /* Namespace */ | 4 /* Value */ |
|
); |
|
const ambient = includesModifier( |
|
node.modifiers, |
|
ts24.SyntaxKind.DeclareKeyword |
|
); |
|
return next( |
|
node, |
|
__privateGet(this, _scope).createOrReuseNamespaceScope( |
|
node.name.text, |
|
exported, |
|
ambient, |
|
ambient && namespaceHasExportStatement(node) |
|
) |
|
); |
|
} |
|
return next( |
|
node, |
|
__privateGet(this, _scope).createOrReuseNamespaceScope( |
|
`"${node.name.text}"`, |
|
false, |
|
true, |
|
namespaceHasExportStatement(node) |
|
) |
|
); |
|
}; |
|
_handleVariableDeclaration = new WeakSet(); |
|
handleVariableDeclaration_fn = function(declarationList) { |
|
const blockScoped = isBlockScopedVariableDeclarationList(declarationList); |
|
const exported = declarationList.parent.kind === ts24.SyntaxKind.VariableStatement && includesModifier( |
|
declarationList.parent.modifiers, |
|
ts24.SyntaxKind.ExportKeyword |
|
); |
|
for (const declaration of declarationList.declarations) { |
|
__privateMethod(this, _handleBindingName, handleBindingName_fn).call(this, declaration.name, blockScoped, exported); |
|
} |
|
}; |
|
function isNamespaceExported(node) { |
|
return node.parent.kind === ts24.SyntaxKind.ModuleDeclaration || includesModifier(node.modifiers, ts24.SyntaxKind.ExportKeyword); |
|
} |
|
function namespaceHasExportStatement(ns) { |
|
if (ns.body === void 0 || ns.body.kind !== ts24.SyntaxKind.ModuleBlock) { |
|
return false; |
|
} |
|
return containsExportStatement(ns.body); |
|
} |
|
function containsExportStatement(block) { |
|
for (const statement of block.statements) { |
|
if (statement.kind === ts24.SyntaxKind.ExportDeclaration || statement.kind === ts24.SyntaxKind.ExportAssignment) { |
|
return true; |
|
} |
|
} |
|
return false; |
|
} |
|
function isBlockScopedVariableDeclarationList(declarationList) { |
|
return (declarationList.flags & ts24.NodeFlags.BlockScoped) !== 0; |
|
} |
|
function forEachDestructuringIdentifier(pattern, fn) { |
|
for (const element of pattern.elements) { |
|
if (element.kind !== ts24.SyntaxKind.BindingElement) { |
|
continue; |
|
} |
|
let result; |
|
if (element.name.kind === ts24.SyntaxKind.Identifier) { |
|
result = fn(element); |
|
} else { |
|
result = forEachDestructuringIdentifier(element.name, fn); |
|
} |
|
if (result) { |
|
return result; |
|
} |
|
} |
|
} |
|
|
|
// src/usage/collectVariableUsage.ts |
|
function collectVariableUsage(sourceFile) { |
|
return new UsageWalker().getUsage(sourceFile); |
|
} |
|
export { |
|
AccessKind, |
|
DeclarationDomain, |
|
UsageDomain, |
|
collectVariableUsage, |
|
forEachComment, |
|
forEachToken, |
|
getAccessKind, |
|
getCallSignaturesOfType, |
|
getPropertyOfType, |
|
getWellKnownSymbolPropertyOfType, |
|
hasDecorators, |
|
hasExpressionInitializer, |
|
hasInitializer, |
|
hasJSDoc, |
|
hasModifiers, |
|
hasType, |
|
hasTypeArguments, |
|
includesModifier, |
|
intersectionTypeParts, |
|
isAbstractKeyword, |
|
isAccessExpression, |
|
isAccessibilityModifier, |
|
isAccessorDeclaration, |
|
isAccessorKeyword, |
|
isAnyKeyword, |
|
isArrayBindingElement, |
|
isArrayBindingOrAssignmentPattern, |
|
isAssertKeyword, |
|
isAssertsKeyword, |
|
isAssignmentKind, |
|
isAssignmentPattern, |
|
isAsyncKeyword, |
|
isAwaitKeyword, |
|
isBigIntKeyword, |
|
isBigIntLiteralType, |
|
isBindingOrAssignmentElementRestIndicator, |
|
isBindingOrAssignmentElementTarget, |
|
isBindingOrAssignmentPattern, |
|
isBindingPattern, |
|
isBlockLike, |
|
isBooleanKeyword, |
|
isBooleanLiteral, |
|
isBooleanLiteralType, |
|
isClassLikeDeclaration, |
|
isClassMemberModifier, |
|
isColonToken, |
|
isCompilerOptionEnabled, |
|
isConditionalType, |
|
isConstAssertionExpression, |
|
isConstKeyword, |
|
isDeclarationName, |
|
isDeclarationWithTypeParameterChildren, |
|
isDeclarationWithTypeParameters, |
|
isDeclareKeyword, |
|
isDefaultKeyword, |
|
isDestructuringPattern, |
|
isDotToken, |
|
isEndOfFileToken, |
|
isEntityNameExpression, |
|
isEntityNameOrEntityNameExpression, |
|
isEnumType, |
|
isEqualsGreaterThanToken, |
|
isEqualsToken, |
|
isEvolvingArrayType, |
|
isExclamationToken, |
|
isExportKeyword, |
|
isFalseKeyword, |
|
isFalseLiteral, |
|
isFalseLiteralType, |
|
isFalsyType, |
|
isForInOrOfStatement, |
|
isFreshableIntrinsicType, |
|
isFreshableType, |
|
isFunctionLikeDeclaration, |
|
isFunctionScopeBoundary, |
|
isImportExpression, |
|
isImportKeyword, |
|
isInKeyword, |
|
isIndexType, |
|
isIndexedAccessType, |
|
isInputFiles, |
|
isInstantiableType, |
|
isIntersectionType, |
|
isIntrinsicAnyType, |
|
isIntrinsicBigIntType, |
|
isIntrinsicBooleanType, |
|
isIntrinsicESSymbolType, |
|
isIntrinsicErrorType, |
|
isIntrinsicNeverType, |
|
isIntrinsicNonPrimitiveType, |
|
isIntrinsicNullType, |
|
isIntrinsicNumberType, |
|
isIntrinsicStringType, |
|
isIntrinsicType, |
|
isIntrinsicUndefinedType, |
|
isIntrinsicUnknownType, |
|
isIntrinsicVoidType, |
|
isIterationStatement, |
|
isJSDocComment, |
|
isJSDocNamespaceBody, |
|
isJSDocNamespaceDeclaration, |
|
isJSDocText, |
|
isJSDocTypeReferencingNode, |
|
isJsonMinusNumericLiteral, |
|
isJsonObjectExpression, |
|
isJsxAttributeLike, |
|
isJsxAttributeValue, |
|
isJsxChild, |
|
isJsxTagNameExpression, |
|
isJsxTagNamePropertyAccess, |
|
isLiteralToken, |
|
isLiteralType, |
|
isModifierFlagSet, |
|
isModuleBody, |
|
isModuleName, |
|
isModuleReference, |
|
isNamedDeclarationWithName, |
|
isNamedImportBindings, |
|
isNamedImportsOrExports, |
|
isNamespaceBody, |
|
isNamespaceDeclaration, |
|
isNeverKeyword, |
|
isNodeFlagSet, |
|
isNullKeyword, |
|
isNullLiteral, |
|
isNumberKeyword, |
|
isNumberLiteralType, |
|
isNumericOrStringLikeLiteral, |
|
isNumericPropertyName, |
|
isObjectBindingOrAssignmentElement, |
|
isObjectBindingOrAssignmentPattern, |
|
isObjectFlagSet, |
|
isObjectKeyword, |
|
isObjectType, |
|
isObjectTypeDeclaration, |
|
isOutKeyword, |
|
isOverrideKeyword, |
|
isParameterPropertyModifier, |
|
isPrivateKeyword, |
|
isPropertyAccessEntityNameExpression, |
|
isPropertyNameLiteral, |
|
isPropertyReadonlyInType, |
|
isProtectedKeyword, |
|
isPseudoLiteralToken, |
|
isPublicKeyword, |
|
isQuestionDotToken, |
|
isQuestionToken, |
|
isReadonlyKeyword, |
|
isSignatureDeclaration, |
|
isStaticKeyword, |
|
isStrictCompilerOptionEnabled, |
|
isStringKeyword, |
|
isStringLiteralType, |
|
isStringMappingType, |
|
isSubstitutionType, |
|
isSuperElementAccessExpression, |
|
isSuperExpression, |
|
isSuperKeyword, |
|
isSuperProperty, |
|
isSuperPropertyAccessExpression, |
|
isSymbolFlagSet, |
|
isSymbolKeyword, |
|
isSyntaxList, |
|
isTemplateLiteralType, |
|
isThenableType, |
|
isThisExpression, |
|
isThisKeyword, |
|
isTrueKeyword, |
|
isTrueLiteral, |
|
isTrueLiteralType, |
|
isTupleType, |
|
isTupleTypeReference, |
|
isTypeFlagSet, |
|
isTypeOnlyCompatibleAliasDeclaration, |
|
isTypeParameter, |
|
isTypeReference, |
|
isTypeReferenceType, |
|
isTypeVariable, |
|
isUndefinedKeyword, |
|
isUnionOrIntersectionType, |
|
isUnionOrIntersectionTypeNode, |
|
isUnionType, |
|
isUniqueESSymbolType, |
|
isUnknownKeyword, |
|
isUnknownLiteralType, |
|
isUnparsedPrologue, |
|
isUnparsedSourceText, |
|
isUnparsedSyntheticReference, |
|
isValidPropertyAccess, |
|
isVariableLikeDeclaration, |
|
isVoidKeyword, |
|
symbolHasReadonlyDeclaration, |
|
typeParts, |
|
unionTypeParts |
|
}; |
|
//# sourceMappingURL=index.js.map
|