NET-Web-API-w-Angular/my-app/node_modules/@angular/compiler-cli/bundles/chunk-ELKFSTAE.js

9088 lines
347 KiB
JavaScript
Executable file

import {createRequire as __cjsCompatRequire} from 'module';
const require = __cjsCompatRequire(import.meta.url);
import {
CompletionKind,
OptimizeFor,
PotentialImportKind,
PotentialImportMode,
SymbolKind
} from "./chunk-6VEEN3ZS.js";
import {
CompilationMode,
ComponentDecoratorHandler,
ComponentScopeKind,
CompoundComponentScopeReader,
CompoundMetadataReader,
CompoundMetadataRegistry,
DirectiveDecoratorHandler,
DtsMetadataReader,
DtsTransformRegistry,
ExportedProviderStatusResolver,
HostDirectivesResolver,
InjectableClassRegistry,
InjectableDecoratorHandler,
LocalMetadataRegistry,
LocalModuleScopeRegistry,
MetaKind,
MetadataDtsModuleScopeResolver,
NgModuleDecoratorHandler,
NoopReferencesRegistry,
PartialEvaluator,
PipeDecoratorHandler,
ResourceRegistry,
SemanticDepGraphUpdater,
TraitCompiler,
TypeCheckScopeRegistry,
aliasTransformFactory,
declarationTransformFactory,
ivyTransformFactory
} from "./chunk-HJWHU6BO.js";
import {
AbsoluteModuleStrategy,
AliasStrategy,
AmbientImport,
COMPILER_ERRORS_WITH_GUIDES,
DefaultImportTracker,
DeferredSymbolTracker,
ERROR_DETAILS_PAGE_BASE_URL,
ErrorCode,
ExtendedTemplateDiagnosticName,
ImportFlags,
ImportManager,
LocalIdentifierStrategy,
LogicalProjectStrategy,
ModuleResolver,
NoopImportRewriter,
PrivateExportAliasingHost,
R3SymbolsImportRewriter,
Reference,
ReferenceEmitter,
RelativePathStrategy,
TypeEmitter,
TypeScriptReflectionHost,
UnifiedModulesAliasingHost,
UnifiedModulesStrategy,
addDiagnosticChain,
assertSuccessfulReferenceEmit,
canEmitType,
getRootDirs,
getSourceFileOrNull,
getTokenAtPosition,
isAssignment,
isDtsPath,
isFatalDiagnosticError,
isNamedClassDeclaration,
isNonDeclarationTsPath,
isSymbolWithValueDeclaration,
makeDiagnostic,
makeDiagnosticChain,
makeRelatedInformation,
ngErrorCode,
normalizeSeparators,
relativePathBetween,
replaceTsWithNgInErrors,
toUnredirectedSourceFile,
translateExpression,
translateType
} from "./chunk-O2GHHXCL.js";
import {
ActivePerfRecorder,
DelegatingPerfRecorder,
PerfCheckpoint,
PerfEvent,
PerfPhase
} from "./chunk-64JBPJBS.js";
import {
LogicalFileSystem,
absoluteFrom,
absoluteFromSourceFile,
dirname,
getFileSystem,
getSourceFileOrError,
join,
resolve
} from "./chunk-UM6JO3VZ.js";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/transformers/api.mjs
var DEFAULT_ERROR_CODE = 100;
var UNKNOWN_ERROR_CODE = 500;
var SOURCE = "angular";
function isTsDiagnostic(diagnostic) {
return diagnostic != null && diagnostic.source !== "angular";
}
var EmitFlags;
(function(EmitFlags2) {
EmitFlags2[EmitFlags2["DTS"] = 1] = "DTS";
EmitFlags2[EmitFlags2["JS"] = 2] = "JS";
EmitFlags2[EmitFlags2["Metadata"] = 4] = "Metadata";
EmitFlags2[EmitFlags2["I18nBundle"] = 8] = "I18nBundle";
EmitFlags2[EmitFlags2["Codegen"] = 16] = "Codegen";
EmitFlags2[EmitFlags2["Default"] = 19] = "Default";
EmitFlags2[EmitFlags2["All"] = 31] = "All";
})(EmitFlags || (EmitFlags = {}));
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/transformers/compiler_host.mjs
import ts from "typescript";
var wrapHostForTest = null;
function createCompilerHost({ options, tsHost = ts.createCompilerHost(options, true) }) {
if (wrapHostForTest !== null) {
tsHost = wrapHostForTest(tsHost);
}
return tsHost;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/entities.mjs
var EntryType;
(function(EntryType2) {
EntryType2["Block"] = "block";
EntryType2["Component"] = "component";
EntryType2["Constant"] = "constant";
EntryType2["Decorator"] = "decorator";
EntryType2["Directive"] = "directive";
EntryType2["Element"] = "element";
EntryType2["Enum"] = "enum";
EntryType2["Function"] = "function";
EntryType2["Interface"] = "interface";
EntryType2["NgModule"] = "ng_module";
EntryType2["Pipe"] = "pipe";
EntryType2["TypeAlias"] = "type_alias";
EntryType2["UndecoratedClass"] = "undecorated_class";
})(EntryType || (EntryType = {}));
var MemberType;
(function(MemberType2) {
MemberType2["Property"] = "property";
MemberType2["Method"] = "method";
MemberType2["Getter"] = "getter";
MemberType2["Setter"] = "setter";
MemberType2["EnumItem"] = "enum_item";
})(MemberType || (MemberType = {}));
var DecoratorType;
(function(DecoratorType2) {
DecoratorType2["Class"] = "class";
DecoratorType2["Member"] = "member";
DecoratorType2["Parameter"] = "parameter";
})(DecoratorType || (DecoratorType = {}));
var MemberTags;
(function(MemberTags2) {
MemberTags2["Abstract"] = "abstract";
MemberTags2["Static"] = "static";
MemberTags2["Readonly"] = "readonly";
MemberTags2["Protected"] = "protected";
MemberTags2["Optional"] = "optional";
MemberTags2["Input"] = "input";
MemberTags2["Output"] = "output";
MemberTags2["Inherited"] = "override";
})(MemberTags || (MemberTags = {}));
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/program.mjs
import { HtmlParser, MessageBundle } from "@angular/compiler";
import ts37 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/transformers/i18n.mjs
import { Xliff, Xliff2, Xmb } from "@angular/compiler";
import * as path from "path";
function i18nGetExtension(formatName) {
const format = formatName.toLowerCase();
switch (format) {
case "xmb":
return "xmb";
case "xlf":
case "xlif":
case "xliff":
case "xlf2":
case "xliff2":
return "xlf";
}
throw new Error(`Unsupported format "${formatName}"`);
}
function i18nExtract(formatName, outFile, host, options, bundle, pathResolve = path.resolve) {
formatName = formatName || "xlf";
const ext = i18nGetExtension(formatName);
const content = i18nSerialize(bundle, formatName, options);
const dstFile = outFile || `messages.${ext}`;
const dstPath = pathResolve(options.outDir || options.basePath, dstFile);
host.writeFile(dstPath, content, false, void 0, []);
return [dstPath];
}
function i18nSerialize(bundle, formatName, options) {
const format = formatName.toLowerCase();
let serializer;
switch (format) {
case "xmb":
serializer = new Xmb();
break;
case "xliff2":
case "xlf2":
serializer = new Xliff2();
break;
case "xlf":
case "xliff":
default:
serializer = new Xliff();
}
return bundle.write(serializer, getPathNormalizer(options.basePath));
}
function getPathNormalizer(basePath) {
return (sourcePath) => {
sourcePath = basePath ? path.relative(basePath, sourcePath) : sourcePath;
return sourcePath.split(path.sep).join("/");
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/typescript_support.mjs
import ts2 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/version_helpers.mjs
function toNumbers(value) {
const suffixIndex = value.lastIndexOf("-");
return value.slice(0, suffixIndex === -1 ? value.length : suffixIndex).split(".").map((segment) => {
const parsed = parseInt(segment, 10);
if (isNaN(parsed)) {
throw Error(`Unable to parse version string ${value}.`);
}
return parsed;
});
}
function compareNumbers(a, b) {
const max = Math.max(a.length, b.length);
const min = Math.min(a.length, b.length);
for (let i = 0; i < min; i++) {
if (a[i] > b[i])
return 1;
if (a[i] < b[i])
return -1;
}
if (min !== max) {
const longestArray = a.length === max ? a : b;
const comparisonResult = a.length === max ? 1 : -1;
for (let i = min; i < max; i++) {
if (longestArray[i] > 0) {
return comparisonResult;
}
}
}
return 0;
}
function compareVersions(v1, v2) {
return compareNumbers(toNumbers(v1), toNumbers(v2));
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/typescript_support.mjs
var MIN_TS_VERSION = "5.2.0";
var MAX_TS_VERSION = "5.4.0";
var tsVersion = ts2.version;
function checkVersion(version, minVersion, maxVersion) {
if (compareVersions(version, minVersion) < 0 || compareVersions(version, maxVersion) >= 0) {
throw new Error(`The Angular Compiler requires TypeScript >=${minVersion} and <${maxVersion} but ${version} was found instead.`);
}
}
function verifySupportedTypeScriptVersion() {
checkVersion(tsVersion, MIN_TS_VERSION, MAX_TS_VERSION);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/core/src/compiler.mjs
import ts35 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/cycles/src/analyzer.mjs
var CycleAnalyzer = class {
constructor(importGraph) {
this.importGraph = importGraph;
this.cachedResults = null;
}
wouldCreateCycle(from, to) {
if (this.cachedResults === null || this.cachedResults.from !== from) {
this.cachedResults = new CycleResults(from, this.importGraph);
}
return this.cachedResults.wouldBeCyclic(to) ? new Cycle(this.importGraph, from, to) : null;
}
recordSyntheticImport(from, to) {
this.cachedResults = null;
this.importGraph.addSyntheticImport(from, to);
}
};
var NgCyclicResult = Symbol("NgCyclicResult");
var CycleResults = class {
constructor(from, importGraph) {
this.from = from;
this.importGraph = importGraph;
this.cyclic = {};
this.acyclic = {};
}
wouldBeCyclic(sf) {
const cached = this.getCachedResult(sf);
if (cached !== null) {
return cached;
}
if (sf === this.from) {
return true;
}
this.markAcyclic(sf);
const imports = this.importGraph.importsOf(sf);
for (const imported of imports) {
if (this.wouldBeCyclic(imported)) {
this.markCyclic(sf);
return true;
}
}
return false;
}
getCachedResult(sf) {
const result = sf[NgCyclicResult];
if (result === this.cyclic) {
return true;
} else if (result === this.acyclic) {
return false;
} else {
return null;
}
}
markCyclic(sf) {
sf[NgCyclicResult] = this.cyclic;
}
markAcyclic(sf) {
sf[NgCyclicResult] = this.acyclic;
}
};
var Cycle = class {
constructor(importGraph, from, to) {
this.importGraph = importGraph;
this.from = from;
this.to = to;
}
getPath() {
return [this.from, ...this.importGraph.findPath(this.to, this.from)];
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/cycles/src/imports.mjs
import ts3 from "typescript";
var ImportGraph = class {
constructor(checker, perf) {
this.checker = checker;
this.perf = perf;
this.imports = /* @__PURE__ */ new Map();
}
importsOf(sf) {
if (!this.imports.has(sf)) {
this.imports.set(sf, this.scanImports(sf));
}
return this.imports.get(sf);
}
findPath(start, end) {
if (start === end) {
return [start];
}
const found = /* @__PURE__ */ new Set([start]);
const queue = [new Found(start, null)];
while (queue.length > 0) {
const current = queue.shift();
const imports = this.importsOf(current.sourceFile);
for (const importedFile of imports) {
if (!found.has(importedFile)) {
const next = new Found(importedFile, current);
if (next.sourceFile === end) {
return next.toPath();
}
found.add(importedFile);
queue.push(next);
}
}
}
return null;
}
addSyntheticImport(sf, imported) {
if (isLocalFile(imported)) {
this.importsOf(sf).add(imported);
}
}
scanImports(sf) {
return this.perf.inPhase(PerfPhase.CycleDetection, () => {
const imports = /* @__PURE__ */ new Set();
for (const stmt of sf.statements) {
if (!ts3.isImportDeclaration(stmt) && !ts3.isExportDeclaration(stmt) || stmt.moduleSpecifier === void 0) {
continue;
}
if (ts3.isImportDeclaration(stmt) && stmt.importClause !== void 0 && isTypeOnlyImportClause(stmt.importClause)) {
continue;
}
const symbol = this.checker.getSymbolAtLocation(stmt.moduleSpecifier);
if (symbol === void 0 || symbol.valueDeclaration === void 0) {
continue;
}
const moduleFile = symbol.valueDeclaration;
if (ts3.isSourceFile(moduleFile) && isLocalFile(moduleFile)) {
imports.add(moduleFile);
}
}
return imports;
});
}
};
function isLocalFile(sf) {
return !sf.isDeclarationFile;
}
function isTypeOnlyImportClause(node) {
if (node.isTypeOnly) {
return true;
}
if (node.namedBindings !== void 0 && ts3.isNamedImports(node.namedBindings) && node.namedBindings.elements.every((specifier) => specifier.isTypeOnly)) {
return true;
}
return false;
}
var Found = class {
constructor(sourceFile, parent) {
this.sourceFile = sourceFile;
this.parent = parent;
}
toPath() {
const array = [];
let current = this;
while (current !== null) {
array.push(current.sourceFile);
current = current.parent;
}
return array.reverse();
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/extractor.mjs
import ts9 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/class_extractor.mjs
import ts6 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/filters.mjs
function isAngularPrivateName(name) {
var _a;
const firstChar = (_a = name[0]) != null ? _a : "";
return firstChar === "\u0275" || firstChar === "_";
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/function_extractor.mjs
import ts5 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/generics_extractor.mjs
function extractGenerics(declaration) {
var _a, _b;
return (_b = (_a = declaration.typeParameters) == null ? void 0 : _a.map((typeParam) => {
var _a2, _b2;
return {
name: typeParam.name.getText(),
constraint: (_a2 = typeParam.constraint) == null ? void 0 : _a2.getText(),
default: (_b2 = typeParam.default) == null ? void 0 : _b2.getText()
};
})) != null ? _b : [];
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/jsdoc_extractor.mjs
import ts4 from "typescript";
var decoratorExpression = /@(?=(Injectable|Component|Directive|Pipe|NgModule|Input|Output|HostBinding|HostListener|Inject|Optional|Self|Host|SkipSelf))/g;
function extractJsDocTags(node) {
const escapedNode = getEscapedNode(node);
return ts4.getJSDocTags(escapedNode).map((t) => {
var _a;
return {
name: t.tagName.getText(),
comment: unescapeAngularDecorators((_a = ts4.getTextOfJSDocComment(t.comment)) != null ? _a : "")
};
});
}
function extractJsDocDescription(node) {
var _a, _b;
const escapedNode = getEscapedNode(node);
const commentOrTag = ts4.getJSDocCommentsAndTags(escapedNode).find((d) => {
return ts4.isJSDoc(d) || ts4.isJSDocParameterTag(d);
});
const comment = (_a = commentOrTag == null ? void 0 : commentOrTag.comment) != null ? _a : "";
const description = typeof comment === "string" ? comment : (_b = ts4.getTextOfJSDocComment(comment)) != null ? _b : "";
return unescapeAngularDecorators(description);
}
function extractRawJsDoc(node) {
var _a, _b;
const comment = (_b = (_a = ts4.getJSDocCommentsAndTags(node).find(ts4.isJSDoc)) == null ? void 0 : _a.getFullText()) != null ? _b : "";
return unescapeAngularDecorators(comment);
}
function getEscapedNode(node) {
if (ts4.isParameter(node)) {
return node;
}
const rawComment = extractRawJsDoc(node);
const escaped = escapeAngularDecorators(rawComment);
const file = ts4.createSourceFile("x.ts", `${escaped}class X {}`, ts4.ScriptTarget.ES2020, true);
return file.statements.find((s) => ts4.isClassDeclaration(s));
}
function escapeAngularDecorators(comment) {
return comment.replace(decoratorExpression, "_NG_AT_");
}
function unescapeAngularDecorators(comment) {
return comment.replace(/_NG_AT_/g, "@");
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/type_extractor.mjs
function extractResolvedTypeString(node, checker) {
return checker.typeToString(checker.getTypeAtLocation(node));
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/function_extractor.mjs
var FunctionExtractor = class {
constructor(name, declaration, typeChecker) {
this.name = name;
this.declaration = declaration;
this.typeChecker = typeChecker;
}
extract() {
const signature = this.typeChecker.getSignatureFromDeclaration(this.declaration);
const returnType = signature ? this.typeChecker.typeToString(this.typeChecker.getReturnTypeOfSignature(signature)) : "unknown";
return {
params: this.extractAllParams(this.declaration.parameters),
name: this.name,
isNewType: ts5.isConstructSignatureDeclaration(this.declaration),
returnType,
entryType: EntryType.Function,
generics: extractGenerics(this.declaration),
description: extractJsDocDescription(this.declaration),
jsdocTags: extractJsDocTags(this.declaration),
rawComment: extractRawJsDoc(this.declaration)
};
}
extractAllParams(params) {
return params.map((param) => ({
name: param.name.getText(),
description: extractJsDocDescription(param),
type: extractResolvedTypeString(param, this.typeChecker),
isOptional: !!(param.questionToken || param.initializer),
isRestParam: !!param.dotDotDotToken
}));
}
getOverloads() {
var _a, _b, _c, _d;
const overloads = [];
const symbol = this.getSymbol();
const declarationCount = (_b = (_a = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _a.length) != null ? _b : 0;
if (declarationCount > 1) {
for (let i = 0; i < declarationCount - 1; i++) {
const overloadDeclaration = (_c = symbol == null ? void 0 : symbol.declarations) == null ? void 0 : _c[i];
if ((overloadDeclaration == null ? void 0 : overloadDeclaration.pos) === this.declaration.pos)
continue;
if (overloadDeclaration && ts5.isFunctionDeclaration(overloadDeclaration) && ((_d = overloadDeclaration.modifiers) == null ? void 0 : _d.some((mod) => mod.kind === ts5.SyntaxKind.ExportKeyword))) {
overloads.push(overloadDeclaration);
}
}
}
return overloads;
}
getSymbol() {
return this.typeChecker.getSymbolsInScope(this.declaration, ts5.SymbolFlags.Function).find((s) => {
var _a;
return s.name === ((_a = this.declaration.name) == null ? void 0 : _a.getText());
});
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/class_extractor.mjs
var ClassExtractor = class {
constructor(declaration, typeChecker) {
this.declaration = declaration;
this.typeChecker = typeChecker;
}
extract() {
return {
name: this.declaration.name.text,
isAbstract: this.isAbstract(),
entryType: ts6.isInterfaceDeclaration(this.declaration) ? EntryType.Interface : EntryType.UndecoratedClass,
members: this.extractSignatures().concat(this.extractAllClassMembers()),
generics: extractGenerics(this.declaration),
description: extractJsDocDescription(this.declaration),
jsdocTags: extractJsDocTags(this.declaration),
rawComment: extractRawJsDoc(this.declaration)
};
}
extractAllClassMembers() {
const members = [];
for (const member of this.getMemberDeclarations()) {
if (this.isMemberExcluded(member))
continue;
const memberEntry = this.extractClassMember(member);
if (memberEntry) {
members.push(memberEntry);
}
}
return members;
}
extractClassMember(memberDeclaration) {
if (this.isMethod(memberDeclaration) && !this.isImplementationForOverload(memberDeclaration)) {
return this.extractMethod(memberDeclaration);
} else if (this.isProperty(memberDeclaration)) {
return this.extractClassProperty(memberDeclaration);
} else if (ts6.isAccessor(memberDeclaration)) {
return this.extractGetterSetter(memberDeclaration);
}
return void 0;
}
extractSignatures() {
return this.computeAllSignatureDeclarations().map((s) => this.extractSignature(s));
}
extractMethod(methodDeclaration) {
const functionExtractor = new FunctionExtractor(methodDeclaration.name.getText(), methodDeclaration, this.typeChecker);
return {
...functionExtractor.extract(),
memberType: MemberType.Method,
memberTags: this.getMemberTags(methodDeclaration)
};
}
extractSignature(signature) {
const functionExtractor = new FunctionExtractor(ts6.isConstructSignatureDeclaration(signature) ? "new" : "", signature, this.typeChecker);
return {
...functionExtractor.extract(),
memberType: MemberType.Method,
memberTags: []
};
}
extractClassProperty(propertyDeclaration) {
return {
name: propertyDeclaration.name.getText(),
type: extractResolvedTypeString(propertyDeclaration, this.typeChecker),
memberType: MemberType.Property,
memberTags: this.getMemberTags(propertyDeclaration),
description: extractJsDocDescription(propertyDeclaration),
jsdocTags: extractJsDocTags(propertyDeclaration)
};
}
extractGetterSetter(accessor) {
return {
...this.extractClassProperty(accessor),
memberType: ts6.isGetAccessor(accessor) ? MemberType.Getter : MemberType.Setter
};
}
getMemberTags(member) {
var _a;
const tags = this.getMemberTagsFromModifiers((_a = member.modifiers) != null ? _a : []);
if (member.questionToken) {
tags.push(MemberTags.Optional);
}
if (member.parent !== this.declaration) {
tags.push(MemberTags.Inherited);
}
return tags;
}
computeAllSignatureDeclarations() {
const type = this.typeChecker.getTypeAtLocation(this.declaration);
const signatures = [
...type.getCallSignatures(),
...type.getConstructSignatures()
];
const result = [];
for (const signature of signatures) {
const decl = signature.getDeclaration();
if (this.isDocumentableSignature(decl) && this.isDocumentableMember(decl)) {
result.push(decl);
}
}
return result;
}
getMemberDeclarations() {
var _a;
const type = this.typeChecker.getTypeAtLocation(this.declaration);
const members = type.getProperties();
const typeOfConstructor = this.typeChecker.getTypeOfSymbol(type.symbol);
const staticMembers = typeOfConstructor.getProperties();
const result = [];
for (const member of [...members, ...staticMembers]) {
const memberDeclarations = (_a = member.getDeclarations()) != null ? _a : [];
for (const memberDeclaration of memberDeclarations) {
if (this.isDocumentableMember(memberDeclaration)) {
result.push(memberDeclaration);
}
}
}
return result;
}
getMemberTagsFromModifiers(mods) {
const tags = [];
for (const mod of mods) {
const tag = this.getTagForMemberModifier(mod);
if (tag)
tags.push(tag);
}
return tags;
}
getTagForMemberModifier(mod) {
switch (mod.kind) {
case ts6.SyntaxKind.StaticKeyword:
return MemberTags.Static;
case ts6.SyntaxKind.ReadonlyKeyword:
return MemberTags.Readonly;
case ts6.SyntaxKind.ProtectedKeyword:
return MemberTags.Protected;
case ts6.SyntaxKind.AbstractKeyword:
return MemberTags.Abstract;
default:
return void 0;
}
}
isMemberExcluded(member) {
var _a;
return !member.name || !this.isDocumentableMember(member) || !!((_a = member.modifiers) == null ? void 0 : _a.some((mod) => mod.kind === ts6.SyntaxKind.PrivateKeyword)) || member.name.getText() === "prototype" || isAngularPrivateName(member.name.getText());
}
isDocumentableMember(member) {
return this.isMethod(member) || this.isProperty(member) || ts6.isAccessor(member);
}
isProperty(member) {
return ts6.isPropertyDeclaration(member) || ts6.isPropertySignature(member);
}
isMethod(member) {
return ts6.isMethodDeclaration(member) || ts6.isMethodSignature(member);
}
isDocumentableSignature(signature) {
return ts6.isConstructSignatureDeclaration(signature) || ts6.isCallSignatureDeclaration(signature);
}
isAbstract() {
var _a;
const modifiers = (_a = this.declaration.modifiers) != null ? _a : [];
return modifiers.some((mod) => mod.kind === ts6.SyntaxKind.AbstractKeyword);
}
isImplementationForOverload(method) {
if (method.kind === ts6.SyntaxKind.MethodSignature)
return false;
const signature = this.typeChecker.getSignatureFromDeclaration(method);
return signature && this.typeChecker.isImplementationOfOverload(signature.declaration);
}
};
var DirectiveExtractor = class extends ClassExtractor {
constructor(declaration, reference, metadata, checker) {
super(declaration, checker);
this.reference = reference;
this.metadata = metadata;
}
extract() {
var _a, _b;
return {
...super.extract(),
isStandalone: this.metadata.isStandalone,
selector: (_a = this.metadata.selector) != null ? _a : "",
exportAs: (_b = this.metadata.exportAs) != null ? _b : [],
entryType: this.metadata.isComponent ? EntryType.Component : EntryType.Directive
};
}
extractClassProperty(propertyDeclaration) {
const entry = super.extractClassProperty(propertyDeclaration);
const inputMetadata = this.getInputMetadata(propertyDeclaration);
if (inputMetadata) {
entry.memberTags.push(MemberTags.Input);
entry.inputAlias = inputMetadata.bindingPropertyName;
entry.isRequiredInput = inputMetadata.required;
}
const outputMetadata = this.getOutputMetadata(propertyDeclaration);
if (outputMetadata) {
entry.memberTags.push(MemberTags.Output);
entry.outputAlias = outputMetadata.bindingPropertyName;
}
return entry;
}
getInputMetadata(prop) {
var _a, _b;
const propName = prop.name.getText();
return (_b = (_a = this.metadata.inputs) == null ? void 0 : _a.getByClassPropertyName(propName)) != null ? _b : void 0;
}
getOutputMetadata(prop) {
var _a, _b, _c;
const propName = prop.name.getText();
return (_c = (_b = (_a = this.metadata) == null ? void 0 : _a.outputs) == null ? void 0 : _b.getByClassPropertyName(propName)) != null ? _c : void 0;
}
};
var PipeExtractor = class extends ClassExtractor {
constructor(declaration, reference, metadata, typeChecker) {
super(declaration, typeChecker);
this.reference = reference;
this.metadata = metadata;
}
extract() {
return {
...super.extract(),
pipeName: this.metadata.name,
entryType: EntryType.Pipe,
isStandalone: this.metadata.isStandalone
};
}
};
var NgModuleExtractor = class extends ClassExtractor {
constructor(declaration, reference, metadata, typeChecker) {
super(declaration, typeChecker);
this.reference = reference;
this.metadata = metadata;
}
extract() {
return {
...super.extract(),
entryType: EntryType.NgModule
};
}
};
function extractClass(classDeclaration, metadataReader, typeChecker) {
const ref = new Reference(classDeclaration);
let extractor;
let directiveMetadata = metadataReader.getDirectiveMetadata(ref);
let pipeMetadata = metadataReader.getPipeMetadata(ref);
let ngModuleMetadata = metadataReader.getNgModuleMetadata(ref);
if (directiveMetadata) {
extractor = new DirectiveExtractor(classDeclaration, ref, directiveMetadata, typeChecker);
} else if (pipeMetadata) {
extractor = new PipeExtractor(classDeclaration, ref, pipeMetadata, typeChecker);
} else if (ngModuleMetadata) {
extractor = new NgModuleExtractor(classDeclaration, ref, ngModuleMetadata, typeChecker);
} else {
extractor = new ClassExtractor(classDeclaration, typeChecker);
}
return extractor.extract();
}
function extractInterface(declaration, typeChecker) {
const extractor = new ClassExtractor(declaration, typeChecker);
return extractor.extract();
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/constant_extractor.mjs
function extractConstant(declaration, typeChecker) {
const resolvedType = typeChecker.getBaseTypeOfLiteralType(typeChecker.getTypeAtLocation(declaration));
const variableStatement = declaration.parent.parent;
const rawComment = extractRawJsDoc(declaration.parent.parent);
return {
name: declaration.name.getText(),
type: typeChecker.typeToString(resolvedType),
entryType: EntryType.Constant,
rawComment,
description: extractJsDocDescription(declaration),
jsdocTags: extractJsDocTags(declaration)
};
}
function isSyntheticAngularConstant(declaration) {
return declaration.name.getText() === "USED_FOR_NG_TYPE_CHECKING";
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/decorator_extractor.mjs
import ts7 from "typescript";
function extractorDecorator(declaration, typeChecker) {
const documentedNode = getDecoratorJsDocNode(declaration);
const decoratorType = getDecoratorType(declaration);
if (!decoratorType) {
throw new Error(`"${declaration.name.getText()} is not a decorator."`);
}
return {
name: declaration.name.getText(),
decoratorType,
entryType: EntryType.Decorator,
rawComment: extractRawJsDoc(documentedNode),
description: extractJsDocDescription(documentedNode),
jsdocTags: extractJsDocTags(documentedNode),
members: getDecoratorOptions(declaration, typeChecker)
};
}
function isDecoratorDeclaration(declaration) {
return !!getDecoratorType(declaration);
}
function isDecoratorOptionsInterface(declaration) {
return declaration.getSourceFile().statements.some((s) => ts7.isVariableStatement(s) && s.declarationList.declarations.some((d) => isDecoratorDeclaration(d) && d.name.getText() === declaration.name.getText()));
}
function getDecoratorType(declaration) {
var _a, _b;
const initializer = (_b = (_a = declaration.initializer) == null ? void 0 : _a.getFullText()) != null ? _b : "";
if (initializer.includes("makeDecorator"))
return DecoratorType.Class;
if (initializer.includes("makePropDecorator"))
return DecoratorType.Member;
if (initializer.includes("makeParamDecorator"))
return DecoratorType.Parameter;
return void 0;
}
function getDecoratorOptions(declaration, typeChecker) {
var _a, _b;
const name = declaration.name.getText();
const optionsDeclaration = declaration.getSourceFile().statements.find((node) => {
return (ts7.isInterfaceDeclaration(node) || ts7.isTypeAliasDeclaration(node)) && node.name.getText() === name;
});
if (!optionsDeclaration) {
throw new Error(`Decorator "${name}" has no corresponding options interface.`);
}
let optionsInterface;
if (ts7.isTypeAliasDeclaration(optionsDeclaration)) {
const aliasedType = typeChecker.getTypeAtLocation(optionsDeclaration.type);
optionsInterface = ((_b = (_a = aliasedType.getSymbol()) == null ? void 0 : _a.getDeclarations()) != null ? _b : []).find((d) => ts7.isInterfaceDeclaration(d));
} else {
optionsInterface = optionsDeclaration;
}
if (!optionsInterface || !ts7.isInterfaceDeclaration(optionsInterface)) {
throw new Error(`Options for decorator "${name}" is not an interface.`);
}
return extractInterface(optionsInterface, typeChecker).members;
}
function getDecoratorJsDocNode(declaration) {
const name = declaration.name.getText();
const decoratorInterface = declaration.getSourceFile().statements.find((s) => {
return ts7.isInterfaceDeclaration(s) && s.name.getText() === `${name}Decorator`;
});
if (!decoratorInterface || !ts7.isInterfaceDeclaration(decoratorInterface)) {
throw new Error(`No interface "${name}Decorator" found.`);
}
const callSignature = decoratorInterface.members.find((node) => {
return ts7.isCallSignatureDeclaration(node) && extractRawJsDoc(node);
});
if (!callSignature || !ts7.isCallSignatureDeclaration(callSignature)) {
throw new Error(`No call signature with JsDoc on "${name}Decorator"`);
}
return callSignature;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/enum_extractor.mjs
import ts8 from "typescript";
function extractEnum(declaration, typeChecker) {
return {
name: declaration.name.getText(),
entryType: EntryType.Enum,
members: extractEnumMembers(declaration, typeChecker),
rawComment: extractRawJsDoc(declaration),
description: extractJsDocDescription(declaration),
jsdocTags: extractJsDocTags(declaration)
};
}
function extractEnumMembers(declaration, checker) {
return declaration.members.map((member) => ({
name: member.name.getText(),
type: extractResolvedTypeString(member, checker),
value: getEnumMemberValue(member),
memberType: MemberType.EnumItem,
jsdocTags: extractJsDocTags(member),
description: extractJsDocDescription(member),
memberTags: []
}));
}
function getEnumMemberValue(memberNode) {
var _a;
const literal = memberNode.getChildren().find((n) => {
return ts8.isNumericLiteral(n) || ts8.isStringLiteral(n) || ts8.isPrefixUnaryExpression(n) && n.operator === ts8.SyntaxKind.MinusToken && ts8.isNumericLiteral(n.operand);
});
return (_a = literal == null ? void 0 : literal.getText()) != null ? _a : "";
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/type_alias_extractor.mjs
function extractTypeAlias(declaration) {
return {
name: declaration.name.getText(),
type: declaration.type.getText(),
entryType: EntryType.TypeAlias,
rawComment: extractRawJsDoc(declaration),
description: extractJsDocDescription(declaration),
jsdocTags: extractJsDocTags(declaration)
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/docs/src/extractor.mjs
var DocsExtractor = class {
constructor(typeChecker, metadataReader) {
this.typeChecker = typeChecker;
this.metadataReader = metadataReader;
}
extractAll(sourceFile) {
const entries = [];
const exportedDeclarations = this.getExportedDeclarations(sourceFile);
for (const [exportName, node] of exportedDeclarations) {
if (isAngularPrivateName(exportName))
continue;
const entry = this.extractDeclaration(node);
if (entry) {
entries.push({ ...entry, name: exportName });
}
}
return entries;
}
extractDeclaration(node) {
if (isNamedClassDeclaration(node)) {
return extractClass(node, this.metadataReader, this.typeChecker);
}
if (ts9.isInterfaceDeclaration(node) && !isIgnoredInterface(node)) {
return extractInterface(node, this.typeChecker);
}
if (ts9.isFunctionDeclaration(node)) {
const functionExtractor = new FunctionExtractor(node.name.getText(), node, this.typeChecker);
return functionExtractor.extract();
}
if (ts9.isVariableDeclaration(node) && !isSyntheticAngularConstant(node)) {
return isDecoratorDeclaration(node) ? extractorDecorator(node, this.typeChecker) : extractConstant(node, this.typeChecker);
}
if (ts9.isTypeAliasDeclaration(node)) {
return extractTypeAlias(node);
}
if (ts9.isEnumDeclaration(node)) {
return extractEnum(node, this.typeChecker);
}
return null;
}
getExportedDeclarations(sourceFile) {
var _a;
const reflector = new TypeScriptReflectionHost(this.typeChecker);
const exportedDeclarationMap = reflector.getExportsOfModule(sourceFile);
let exportedDeclarations = Array.from((_a = exportedDeclarationMap == null ? void 0 : exportedDeclarationMap.entries()) != null ? _a : []).map(([exportName, declaration]) => [exportName, declaration.node]);
const declarationCount = exportedDeclarations.length;
for (let i = 0; i < declarationCount; i++) {
const [exportName, declaration] = exportedDeclarations[i];
if (ts9.isFunctionDeclaration(declaration)) {
const extractor = new FunctionExtractor(exportName, declaration, this.typeChecker);
const overloads = extractor.getOverloads().map((overload) => [exportName, overload]);
exportedDeclarations.push(...overloads);
}
}
return exportedDeclarations.sort(([a, declarationA], [b, declarationB]) => declarationA.pos - declarationB.pos);
}
};
function isIgnoredInterface(node) {
return node.name.getText().endsWith("Decorator") || isDecoratorOptionsInterface(node);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/entry_point/src/generator.mjs
import ts10 from "typescript";
var FlatIndexGenerator = class {
constructor(entryPoint, relativeFlatIndexPath, moduleName) {
this.entryPoint = entryPoint;
this.moduleName = moduleName;
this.shouldEmit = true;
this.flatIndexPath = join(dirname(entryPoint), relativeFlatIndexPath).replace(/\.js$/, "") + ".ts";
}
makeTopLevelShim() {
const relativeEntryPoint = relativePathBetween(this.flatIndexPath, this.entryPoint);
const contents = `/**
* Generated bundle index. Do not edit.
*/
export * from '${relativeEntryPoint}';
`;
const genFile = ts10.createSourceFile(this.flatIndexPath, contents, ts10.ScriptTarget.ES2015, true, ts10.ScriptKind.TS);
if (this.moduleName !== null) {
genFile.moduleName = this.moduleName;
}
return genFile;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/entry_point/src/logic.mjs
function findFlatIndexEntryPoint(rootFiles) {
const tsFiles = rootFiles.filter((file) => isNonDeclarationTsPath(file));
let resolvedEntryPoint = null;
if (tsFiles.length === 1) {
resolvedEntryPoint = tsFiles[0];
} else {
for (const tsFile of tsFiles) {
if (getFileSystem().basename(tsFile) === "index.ts" && (resolvedEntryPoint === null || tsFile.length <= resolvedEntryPoint.length)) {
resolvedEntryPoint = tsFile;
}
}
}
return resolvedEntryPoint;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/entry_point/src/private_export_checker.mjs
import ts11 from "typescript";
function checkForPrivateExports(entryPoint, checker, refGraph) {
const diagnostics = [];
const topLevelExports = /* @__PURE__ */ new Set();
const moduleSymbol = checker.getSymbolAtLocation(entryPoint);
if (moduleSymbol === void 0) {
throw new Error(`Internal error: failed to get symbol for entrypoint`);
}
const exportedSymbols = checker.getExportsOfModule(moduleSymbol);
exportedSymbols.forEach((symbol) => {
if (symbol.flags & ts11.SymbolFlags.Alias) {
symbol = checker.getAliasedSymbol(symbol);
}
const decl = symbol.valueDeclaration;
if (decl !== void 0) {
topLevelExports.add(decl);
}
});
const checkedSet = /* @__PURE__ */ new Set();
topLevelExports.forEach((mainExport) => {
refGraph.transitiveReferencesOf(mainExport).forEach((transitiveReference) => {
if (checkedSet.has(transitiveReference)) {
return;
}
checkedSet.add(transitiveReference);
if (!topLevelExports.has(transitiveReference)) {
const descriptor = getDescriptorOfDeclaration(transitiveReference);
const name = getNameOfDeclaration(transitiveReference);
let visibleVia = "NgModule exports";
const transitivePath = refGraph.pathFrom(mainExport, transitiveReference);
if (transitivePath !== null) {
visibleVia = transitivePath.map((seg) => getNameOfDeclaration(seg)).join(" -> ");
}
const diagnostic = {
category: ts11.DiagnosticCategory.Error,
code: ngErrorCode(ErrorCode.SYMBOL_NOT_EXPORTED),
file: transitiveReference.getSourceFile(),
...getPosOfDeclaration(transitiveReference),
messageText: `Unsupported private ${descriptor} ${name}. This ${descriptor} is visible to consumers via ${visibleVia}, but is not exported from the top-level library entrypoint.`
};
diagnostics.push(diagnostic);
}
});
});
return diagnostics;
}
function getPosOfDeclaration(decl) {
const node = getIdentifierOfDeclaration(decl) || decl;
return {
start: node.getStart(),
length: node.getEnd() + 1 - node.getStart()
};
}
function getIdentifierOfDeclaration(decl) {
if ((ts11.isClassDeclaration(decl) || ts11.isVariableDeclaration(decl) || ts11.isFunctionDeclaration(decl)) && decl.name !== void 0 && ts11.isIdentifier(decl.name)) {
return decl.name;
} else {
return null;
}
}
function getNameOfDeclaration(decl) {
const id = getIdentifierOfDeclaration(decl);
return id !== null ? id.text : "(unnamed)";
}
function getDescriptorOfDeclaration(decl) {
switch (decl.kind) {
case ts11.SyntaxKind.ClassDeclaration:
return "class";
case ts11.SyntaxKind.FunctionDeclaration:
return "function";
case ts11.SyntaxKind.VariableDeclaration:
return "variable";
case ts11.SyntaxKind.EnumDeclaration:
return "enum";
default:
return "declaration";
}
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/entry_point/src/reference_graph.mjs
var ReferenceGraph = class {
constructor() {
this.references = /* @__PURE__ */ new Map();
}
add(from, to) {
if (!this.references.has(from)) {
this.references.set(from, /* @__PURE__ */ new Set());
}
this.references.get(from).add(to);
}
transitiveReferencesOf(target) {
const set = /* @__PURE__ */ new Set();
this.collectTransitiveReferences(set, target);
return set;
}
pathFrom(source, target) {
return this.collectPathFrom(source, target, /* @__PURE__ */ new Set());
}
collectPathFrom(source, target, seen) {
if (source === target) {
return [target];
} else if (seen.has(source)) {
return null;
}
seen.add(source);
if (!this.references.has(source)) {
return null;
} else {
let candidatePath = null;
this.references.get(source).forEach((edge) => {
if (candidatePath !== null) {
return;
}
const partialPath = this.collectPathFrom(edge, target, seen);
if (partialPath !== null) {
candidatePath = [source, ...partialPath];
}
});
return candidatePath;
}
}
collectTransitiveReferences(set, decl) {
if (this.references.has(decl)) {
this.references.get(decl).forEach((ref) => {
if (!set.has(ref)) {
set.add(ref);
this.collectTransitiveReferences(set, ref);
}
});
}
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/program_driver/src/api.mjs
var NgOriginalFile = Symbol("NgOriginalFile");
var UpdateMode;
(function(UpdateMode2) {
UpdateMode2[UpdateMode2["Complete"] = 0] = "Complete";
UpdateMode2[UpdateMode2["Incremental"] = 1] = "Incremental";
})(UpdateMode || (UpdateMode = {}));
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/program_driver/src/ts_create_program_driver.mjs
import ts13 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/shims/src/adapter.mjs
import ts12 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/shims/src/expando.mjs
var NgExtension = Symbol("NgExtension");
function isExtended(sf) {
return sf[NgExtension] !== void 0;
}
function sfExtensionData(sf) {
const extSf = sf;
if (extSf[NgExtension] !== void 0) {
return extSf[NgExtension];
}
const extension = {
isTopLevelShim: false,
fileShim: null,
originalReferencedFiles: null,
taggedReferenceFiles: null
};
extSf[NgExtension] = extension;
return extension;
}
function isFileShimSourceFile(sf) {
return isExtended(sf) && sf[NgExtension].fileShim !== null;
}
function isShim(sf) {
return isExtended(sf) && (sf[NgExtension].fileShim !== null || sf[NgExtension].isTopLevelShim);
}
function copyFileShimData(from, to) {
if (!isFileShimSourceFile(from)) {
return;
}
sfExtensionData(to).fileShim = sfExtensionData(from).fileShim;
}
function untagAllTsFiles(program) {
for (const sf of program.getSourceFiles()) {
untagTsFile(sf);
}
}
function retagAllTsFiles(program) {
for (const sf of program.getSourceFiles()) {
retagTsFile(sf);
}
}
function untagTsFile(sf) {
if (sf.isDeclarationFile || !isExtended(sf)) {
return;
}
const ext = sfExtensionData(sf);
if (ext.originalReferencedFiles !== null) {
sf.referencedFiles = ext.originalReferencedFiles;
}
}
function retagTsFile(sf) {
if (sf.isDeclarationFile || !isExtended(sf)) {
return;
}
const ext = sfExtensionData(sf);
if (ext.taggedReferenceFiles !== null) {
sf.referencedFiles = ext.taggedReferenceFiles;
}
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/shims/src/util.mjs
var TS_EXTENSIONS = /\.tsx?$/i;
function makeShimFileName(fileName, suffix) {
return absoluteFrom(fileName.replace(TS_EXTENSIONS, suffix));
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/shims/src/adapter.mjs
var ShimAdapter = class {
constructor(delegate, tsRootFiles, topLevelGenerators, perFileGenerators, oldProgram) {
this.delegate = delegate;
this.shims = /* @__PURE__ */ new Map();
this.priorShims = /* @__PURE__ */ new Map();
this.notShims = /* @__PURE__ */ new Set();
this.generators = [];
this.ignoreForEmit = /* @__PURE__ */ new Set();
this.extensionPrefixes = [];
for (const gen of perFileGenerators) {
const pattern = `^(.*)\\.${gen.extensionPrefix}\\.ts$`;
const regexp = new RegExp(pattern, "i");
this.generators.push({
generator: gen,
test: regexp,
suffix: `.${gen.extensionPrefix}.ts`
});
this.extensionPrefixes.push(gen.extensionPrefix);
}
const extraInputFiles = [];
for (const gen of topLevelGenerators) {
const sf = gen.makeTopLevelShim();
sfExtensionData(sf).isTopLevelShim = true;
if (!gen.shouldEmit) {
this.ignoreForEmit.add(sf);
}
const fileName = absoluteFromSourceFile(sf);
this.shims.set(fileName, sf);
extraInputFiles.push(fileName);
}
for (const rootFile of tsRootFiles) {
for (const gen of this.generators) {
extraInputFiles.push(makeShimFileName(rootFile, gen.suffix));
}
}
this.extraInputFiles = extraInputFiles;
if (oldProgram !== null) {
for (const oldSf of oldProgram.getSourceFiles()) {
if (oldSf.isDeclarationFile || !isFileShimSourceFile(oldSf)) {
continue;
}
this.priorShims.set(absoluteFromSourceFile(oldSf), oldSf);
}
}
}
maybeGenerate(fileName) {
if (this.notShims.has(fileName)) {
return null;
} else if (this.shims.has(fileName)) {
return this.shims.get(fileName);
}
if (isDtsPath(fileName)) {
this.notShims.add(fileName);
return null;
}
for (const record of this.generators) {
const match = record.test.exec(fileName);
if (match === null) {
continue;
}
const prefix = match[1];
let baseFileName = absoluteFrom(prefix + ".ts");
let inputFile = this.delegate.getSourceFile(baseFileName, ts12.ScriptTarget.Latest);
if (inputFile === void 0) {
baseFileName = absoluteFrom(prefix + ".tsx");
inputFile = this.delegate.getSourceFile(baseFileName, ts12.ScriptTarget.Latest);
}
if (inputFile === void 0 || isShim(inputFile)) {
return void 0;
}
return this.generateSpecific(fileName, record.generator, inputFile);
}
this.notShims.add(fileName);
return null;
}
generateSpecific(fileName, generator, inputFile) {
let priorShimSf = null;
if (this.priorShims.has(fileName)) {
priorShimSf = this.priorShims.get(fileName);
this.priorShims.delete(fileName);
}
const shimSf = generator.generateShimForFile(inputFile, fileName, priorShimSf);
sfExtensionData(shimSf).fileShim = {
extension: generator.extensionPrefix,
generatedFrom: absoluteFromSourceFile(inputFile)
};
if (!generator.shouldEmit) {
this.ignoreForEmit.add(shimSf);
}
this.shims.set(fileName, shimSf);
return shimSf;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/shims/src/reference_tagger.mjs
var ShimReferenceTagger = class {
constructor(shimExtensions) {
this.tagged = /* @__PURE__ */ new Set();
this.enabled = true;
this.suffixes = shimExtensions.map((extension) => `.${extension}.ts`);
}
tag(sf) {
if (!this.enabled || sf.isDeclarationFile || isShim(sf) || this.tagged.has(sf) || !isNonDeclarationTsPath(sf.fileName)) {
return;
}
const ext = sfExtensionData(sf);
if (ext.originalReferencedFiles === null) {
ext.originalReferencedFiles = sf.referencedFiles;
}
const referencedFiles = [...ext.originalReferencedFiles];
const sfPath = absoluteFromSourceFile(sf);
for (const suffix of this.suffixes) {
referencedFiles.push({
fileName: makeShimFileName(sfPath, suffix),
pos: 0,
end: 0
});
}
ext.taggedReferenceFiles = referencedFiles;
sf.referencedFiles = referencedFiles;
this.tagged.add(sf);
}
finalize() {
this.enabled = false;
this.tagged.clear();
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/program_driver/src/ts_create_program_driver.mjs
var DelegatingCompilerHost = class {
get jsDocParsingMode() {
return this.delegate.jsDocParsingMode;
}
set jsDocParsingMode(mode) {
this.delegate.jsDocParsingMode = mode;
}
constructor(delegate) {
this.delegate = delegate;
this.createHash = this.delegateMethod("createHash");
this.directoryExists = this.delegateMethod("directoryExists");
this.getCancellationToken = this.delegateMethod("getCancellationToken");
this.getCanonicalFileName = this.delegateMethod("getCanonicalFileName");
this.getCurrentDirectory = this.delegateMethod("getCurrentDirectory");
this.getDefaultLibFileName = this.delegateMethod("getDefaultLibFileName");
this.getDefaultLibLocation = this.delegateMethod("getDefaultLibLocation");
this.getDirectories = this.delegateMethod("getDirectories");
this.getEnvironmentVariable = this.delegateMethod("getEnvironmentVariable");
this.getNewLine = this.delegateMethod("getNewLine");
this.getParsedCommandLine = this.delegateMethod("getParsedCommandLine");
this.getSourceFileByPath = this.delegateMethod("getSourceFileByPath");
this.readDirectory = this.delegateMethod("readDirectory");
this.readFile = this.delegateMethod("readFile");
this.realpath = this.delegateMethod("realpath");
this.resolveModuleNames = this.delegateMethod("resolveModuleNames");
this.resolveTypeReferenceDirectives = this.delegateMethod("resolveTypeReferenceDirectives");
this.trace = this.delegateMethod("trace");
this.useCaseSensitiveFileNames = this.delegateMethod("useCaseSensitiveFileNames");
this.getModuleResolutionCache = this.delegateMethod("getModuleResolutionCache");
this.hasInvalidatedResolutions = this.delegateMethod("hasInvalidatedResolutions");
this.resolveModuleNameLiterals = this.delegateMethod("resolveModuleNameLiterals");
this.resolveTypeReferenceDirectiveReferences = this.delegateMethod("resolveTypeReferenceDirectiveReferences");
}
delegateMethod(name) {
return this.delegate[name] !== void 0 ? this.delegate[name].bind(this.delegate) : void 0;
}
};
var UpdatedProgramHost = class extends DelegatingCompilerHost {
constructor(sfMap, originalProgram, delegate, shimExtensionPrefixes) {
super(delegate);
this.originalProgram = originalProgram;
this.shimExtensionPrefixes = shimExtensionPrefixes;
this.shimTagger = new ShimReferenceTagger(this.shimExtensionPrefixes);
this.sfMap = sfMap;
}
getSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
let delegateSf = this.originalProgram.getSourceFile(fileName);
if (delegateSf === void 0) {
delegateSf = this.delegate.getSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile);
}
if (delegateSf === void 0) {
return void 0;
}
let sf;
if (this.sfMap.has(fileName)) {
sf = this.sfMap.get(fileName);
copyFileShimData(delegateSf, sf);
} else {
sf = delegateSf;
}
sf = toUnredirectedSourceFile(sf);
this.shimTagger.tag(sf);
return sf;
}
postProgramCreationCleanup() {
this.shimTagger.finalize();
}
writeFile() {
throw new Error(`TypeCheckProgramHost should never write files`);
}
fileExists(fileName) {
return this.sfMap.has(fileName) || this.delegate.fileExists(fileName);
}
};
var TsCreateProgramDriver = class {
constructor(originalProgram, originalHost, options, shimExtensionPrefixes) {
this.originalProgram = originalProgram;
this.originalHost = originalHost;
this.options = options;
this.shimExtensionPrefixes = shimExtensionPrefixes;
this.sfMap = /* @__PURE__ */ new Map();
this.supportsInlineOperations = true;
this.program = this.originalProgram;
}
getProgram() {
return this.program;
}
updateFiles(contents, updateMode) {
if (contents.size === 0) {
if (updateMode !== UpdateMode.Complete || this.sfMap.size === 0) {
return;
}
}
if (updateMode === UpdateMode.Complete) {
this.sfMap.clear();
}
for (const [filePath, { newText, originalFile }] of contents.entries()) {
const sf = ts13.createSourceFile(filePath, newText, ts13.ScriptTarget.Latest, true);
if (originalFile !== null) {
sf[NgOriginalFile] = originalFile;
}
this.sfMap.set(filePath, sf);
}
const host = new UpdatedProgramHost(this.sfMap, this.originalProgram, this.originalHost, this.shimExtensionPrefixes);
const oldProgram = this.program;
retagAllTsFiles(oldProgram);
this.program = ts13.createProgram({
host,
rootNames: this.program.getRootFileNames(),
options: this.options,
oldProgram
});
host.postProgramCreationCleanup();
untagAllTsFiles(this.program);
untagAllTsFiles(oldProgram);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/incremental/src/dependency_tracking.mjs
var FileDependencyGraph = class {
constructor() {
this.nodes = /* @__PURE__ */ new Map();
}
addDependency(from, on) {
this.nodeFor(from).dependsOn.add(absoluteFromSourceFile(on));
}
addResourceDependency(from, resource) {
this.nodeFor(from).usesResources.add(resource);
}
recordDependencyAnalysisFailure(file) {
this.nodeFor(file).failedAnalysis = true;
}
getResourceDependencies(from) {
const node = this.nodes.get(from);
return node ? [...node.usesResources] : [];
}
updateWithPhysicalChanges(previous, changedTsPaths, deletedTsPaths, changedResources) {
const logicallyChanged = /* @__PURE__ */ new Set();
for (const sf of previous.nodes.keys()) {
const sfPath = absoluteFromSourceFile(sf);
const node = previous.nodeFor(sf);
if (isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources)) {
logicallyChanged.add(sfPath);
} else if (!deletedTsPaths.has(sfPath)) {
this.nodes.set(sf, {
dependsOn: new Set(node.dependsOn),
usesResources: new Set(node.usesResources),
failedAnalysis: false
});
}
}
return logicallyChanged;
}
nodeFor(sf) {
if (!this.nodes.has(sf)) {
this.nodes.set(sf, {
dependsOn: /* @__PURE__ */ new Set(),
usesResources: /* @__PURE__ */ new Set(),
failedAnalysis: false
});
}
return this.nodes.get(sf);
}
};
function isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources) {
if (node.failedAnalysis) {
return true;
}
const sfPath = absoluteFromSourceFile(sf);
if (changedTsPaths.has(sfPath) || deletedTsPaths.has(sfPath)) {
return true;
}
for (const dep of node.dependsOn) {
if (changedTsPaths.has(dep) || deletedTsPaths.has(dep)) {
return true;
}
}
for (const dep of node.usesResources) {
if (changedResources.has(dep)) {
return true;
}
}
return false;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/incremental/src/state.mjs
var IncrementalStateKind;
(function(IncrementalStateKind2) {
IncrementalStateKind2[IncrementalStateKind2["Fresh"] = 0] = "Fresh";
IncrementalStateKind2[IncrementalStateKind2["Delta"] = 1] = "Delta";
IncrementalStateKind2[IncrementalStateKind2["Analyzed"] = 2] = "Analyzed";
})(IncrementalStateKind || (IncrementalStateKind = {}));
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/incremental/src/incremental.mjs
var PhaseKind;
(function(PhaseKind2) {
PhaseKind2[PhaseKind2["Analysis"] = 0] = "Analysis";
PhaseKind2[PhaseKind2["TypeCheckAndEmit"] = 1] = "TypeCheckAndEmit";
})(PhaseKind || (PhaseKind = {}));
var IncrementalCompilation = class {
constructor(state, depGraph, versions, step) {
this.depGraph = depGraph;
this.versions = versions;
this.step = step;
this._state = state;
this.phase = {
kind: PhaseKind.Analysis,
semanticDepGraphUpdater: new SemanticDepGraphUpdater(step !== null ? step.priorState.semanticDepGraph : null)
};
}
static fresh(program, versions) {
const state = {
kind: IncrementalStateKind.Fresh
};
return new IncrementalCompilation(state, new FileDependencyGraph(), versions, null);
}
static incremental(program, newVersions, oldProgram, oldState, modifiedResourceFiles, perf) {
return perf.inPhase(PerfPhase.Reconciliation, () => {
const physicallyChangedTsFiles = /* @__PURE__ */ new Set();
const changedResourceFiles = new Set(modifiedResourceFiles != null ? modifiedResourceFiles : []);
let priorAnalysis;
switch (oldState.kind) {
case IncrementalStateKind.Fresh:
return IncrementalCompilation.fresh(program, newVersions);
case IncrementalStateKind.Analyzed:
priorAnalysis = oldState;
break;
case IncrementalStateKind.Delta:
priorAnalysis = oldState.lastAnalyzedState;
for (const sfPath of oldState.physicallyChangedTsFiles) {
physicallyChangedTsFiles.add(sfPath);
}
for (const resourcePath of oldState.changedResourceFiles) {
changedResourceFiles.add(resourcePath);
}
break;
}
const oldVersions = priorAnalysis.versions;
const oldFilesArray = oldProgram.getSourceFiles().map(toOriginalSourceFile);
const oldFiles = new Set(oldFilesArray);
const deletedTsFiles = new Set(oldFilesArray.map((sf) => absoluteFromSourceFile(sf)));
for (const possiblyRedirectedNewFile of program.getSourceFiles()) {
const sf = toOriginalSourceFile(possiblyRedirectedNewFile);
const sfPath = absoluteFromSourceFile(sf);
deletedTsFiles.delete(sfPath);
if (oldFiles.has(sf)) {
if (oldVersions === null || newVersions === null) {
continue;
}
if (oldVersions.has(sfPath) && newVersions.has(sfPath) && oldVersions.get(sfPath) === newVersions.get(sfPath)) {
continue;
}
}
if (sf.isDeclarationFile) {
return IncrementalCompilation.fresh(program, newVersions);
}
physicallyChangedTsFiles.add(sfPath);
}
for (const deletedFileName of deletedTsFiles) {
physicallyChangedTsFiles.delete(resolve(deletedFileName));
}
const depGraph = new FileDependencyGraph();
const logicallyChangedTsFiles = depGraph.updateWithPhysicalChanges(priorAnalysis.depGraph, physicallyChangedTsFiles, deletedTsFiles, changedResourceFiles);
for (const sfPath of physicallyChangedTsFiles) {
logicallyChangedTsFiles.add(sfPath);
}
const state = {
kind: IncrementalStateKind.Delta,
physicallyChangedTsFiles,
changedResourceFiles,
lastAnalyzedState: priorAnalysis
};
return new IncrementalCompilation(state, depGraph, newVersions, {
priorState: priorAnalysis,
logicallyChangedTsFiles
});
});
}
get state() {
return this._state;
}
get semanticDepGraphUpdater() {
if (this.phase.kind !== PhaseKind.Analysis) {
throw new Error(`AssertionError: Cannot update the SemanticDepGraph after analysis completes`);
}
return this.phase.semanticDepGraphUpdater;
}
recordSuccessfulAnalysis(traitCompiler) {
if (this.phase.kind !== PhaseKind.Analysis) {
throw new Error(`AssertionError: Incremental compilation in phase ${PhaseKind[this.phase.kind]}, expected Analysis`);
}
const { needsEmit, needsTypeCheckEmit, newGraph } = this.phase.semanticDepGraphUpdater.finalize();
let emitted;
if (this.step === null) {
emitted = /* @__PURE__ */ new Set();
} else {
emitted = new Set(this.step.priorState.emitted);
for (const sfPath of this.step.logicallyChangedTsFiles) {
emitted.delete(sfPath);
}
for (const sfPath of needsEmit) {
emitted.delete(sfPath);
}
}
this._state = {
kind: IncrementalStateKind.Analyzed,
versions: this.versions,
depGraph: this.depGraph,
semanticDepGraph: newGraph,
priorAnalysis: traitCompiler.getAnalyzedRecords(),
typeCheckResults: null,
emitted
};
this.phase = {
kind: PhaseKind.TypeCheckAndEmit,
needsEmit,
needsTypeCheckEmit
};
}
recordSuccessfulTypeCheck(results) {
if (this._state.kind !== IncrementalStateKind.Analyzed) {
throw new Error(`AssertionError: Expected successfully analyzed compilation.`);
} else if (this.phase.kind !== PhaseKind.TypeCheckAndEmit) {
throw new Error(`AssertionError: Incremental compilation in phase ${PhaseKind[this.phase.kind]}, expected TypeCheck`);
}
this._state.typeCheckResults = results;
}
recordSuccessfulEmit(sf) {
if (this._state.kind !== IncrementalStateKind.Analyzed) {
throw new Error(`AssertionError: Expected successfully analyzed compilation.`);
}
this._state.emitted.add(absoluteFromSourceFile(sf));
}
priorAnalysisFor(sf) {
if (this.step === null) {
return null;
}
const sfPath = absoluteFromSourceFile(sf);
if (this.step.logicallyChangedTsFiles.has(sfPath)) {
return null;
}
const priorAnalysis = this.step.priorState.priorAnalysis;
if (!priorAnalysis.has(sf)) {
return null;
}
return priorAnalysis.get(sf);
}
priorTypeCheckingResultsFor(sf) {
if (this.phase.kind !== PhaseKind.TypeCheckAndEmit) {
throw new Error(`AssertionError: Expected successfully analyzed compilation.`);
}
if (this.step === null) {
return null;
}
const sfPath = absoluteFromSourceFile(sf);
if (this.step.logicallyChangedTsFiles.has(sfPath) || this.phase.needsTypeCheckEmit.has(sfPath)) {
return null;
}
if (this.step.priorState.typeCheckResults === null || !this.step.priorState.typeCheckResults.has(sfPath)) {
return null;
}
const priorResults = this.step.priorState.typeCheckResults.get(sfPath);
if (priorResults.hasInlines) {
return null;
}
return priorResults;
}
safeToSkipEmit(sf) {
if (this.step === null) {
return false;
}
const sfPath = absoluteFromSourceFile(sf);
if (this.step.logicallyChangedTsFiles.has(sfPath)) {
return false;
}
if (this.phase.kind !== PhaseKind.TypeCheckAndEmit) {
throw new Error(`AssertionError: Expected successful analysis before attempting to emit files`);
}
if (this.phase.needsEmit.has(sfPath)) {
return false;
}
return this.step.priorState.emitted.has(sfPath);
}
};
function toOriginalSourceFile(sf) {
const unredirectedSf = toUnredirectedSourceFile(sf);
const originalFile = unredirectedSf[NgOriginalFile];
if (originalFile !== void 0) {
return originalFile;
} else {
return unredirectedSf;
}
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/incremental/src/strategy.mjs
var TrackedIncrementalBuildStrategy = class {
constructor() {
this.state = null;
this.isSet = false;
}
getIncrementalState() {
return this.state;
}
setIncrementalState(state) {
this.state = state;
this.isSet = true;
}
toNextBuildStrategy() {
const strategy = new TrackedIncrementalBuildStrategy();
strategy.state = this.isSet ? this.state : null;
return strategy;
}
};
var PatchedProgramIncrementalBuildStrategy = class {
getIncrementalState(program) {
const state = program[SYM_INCREMENTAL_STATE];
if (state === void 0) {
return null;
}
return state;
}
setIncrementalState(state, program) {
program[SYM_INCREMENTAL_STATE] = state;
}
toNextBuildStrategy() {
return this;
}
};
var SYM_INCREMENTAL_STATE = Symbol("NgIncrementalState");
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/indexer/src/api.mjs
var IdentifierKind;
(function(IdentifierKind2) {
IdentifierKind2[IdentifierKind2["Property"] = 0] = "Property";
IdentifierKind2[IdentifierKind2["Method"] = 1] = "Method";
IdentifierKind2[IdentifierKind2["Element"] = 2] = "Element";
IdentifierKind2[IdentifierKind2["Template"] = 3] = "Template";
IdentifierKind2[IdentifierKind2["Attribute"] = 4] = "Attribute";
IdentifierKind2[IdentifierKind2["Reference"] = 5] = "Reference";
IdentifierKind2[IdentifierKind2["Variable"] = 6] = "Variable";
})(IdentifierKind || (IdentifierKind = {}));
var AbsoluteSourceSpan = class {
constructor(start, end) {
this.start = start;
this.end = end;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/indexer/src/context.mjs
var IndexingContext = class {
constructor() {
this.components = /* @__PURE__ */ new Set();
}
addComponent(info) {
this.components.add(info);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/indexer/src/transform.mjs
import { ParseSourceFile } from "@angular/compiler";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/indexer/src/template.mjs
import { ASTWithSource, ImplicitReceiver, PropertyRead, PropertyWrite, RecursiveAstVisitor, TmplAstBoundDeferredTrigger, TmplAstElement, TmplAstRecursiveVisitor, TmplAstReference, TmplAstTemplate } from "@angular/compiler";
var ExpressionVisitor = class extends RecursiveAstVisitor {
constructor(expressionStr, absoluteOffset, boundTemplate, targetToIdentifier) {
super();
this.expressionStr = expressionStr;
this.absoluteOffset = absoluteOffset;
this.boundTemplate = boundTemplate;
this.targetToIdentifier = targetToIdentifier;
this.identifiers = [];
this.errors = [];
}
static getIdentifiers(ast, source, absoluteOffset, boundTemplate, targetToIdentifier) {
const visitor = new ExpressionVisitor(source, absoluteOffset, boundTemplate, targetToIdentifier);
visitor.visit(ast);
return { identifiers: visitor.identifiers, errors: visitor.errors };
}
visit(ast) {
ast.visit(this);
}
visitPropertyRead(ast, context) {
this.visitIdentifier(ast, IdentifierKind.Property);
super.visitPropertyRead(ast, context);
}
visitPropertyWrite(ast, context) {
this.visitIdentifier(ast, IdentifierKind.Property);
super.visitPropertyWrite(ast, context);
}
visitIdentifier(ast, kind) {
if (!(ast.receiver instanceof ImplicitReceiver)) {
return;
}
let identifierStart = ast.sourceSpan.start - this.absoluteOffset;
if (ast instanceof PropertyRead || ast instanceof PropertyWrite) {
identifierStart = ast.nameSpan.start - this.absoluteOffset;
}
if (!this.expressionStr.substring(identifierStart).startsWith(ast.name)) {
this.errors.push(new Error(`Impossible state: "${ast.name}" not found in "${this.expressionStr}" at location ${identifierStart}`));
return;
}
const absoluteStart = this.absoluteOffset + identifierStart;
const span = new AbsoluteSourceSpan(absoluteStart, absoluteStart + ast.name.length);
const targetAst = this.boundTemplate.getExpressionTarget(ast);
const target = targetAst ? this.targetToIdentifier(targetAst) : null;
const identifier = {
name: ast.name,
span,
kind,
target
};
this.identifiers.push(identifier);
}
};
var TemplateVisitor = class extends TmplAstRecursiveVisitor {
constructor(boundTemplate) {
super();
this.boundTemplate = boundTemplate;
this.identifiers = /* @__PURE__ */ new Set();
this.errors = [];
this.targetIdentifierCache = /* @__PURE__ */ new Map();
this.elementAndTemplateIdentifierCache = /* @__PURE__ */ new Map();
}
visit(node) {
node.visit(this);
}
visitAll(nodes) {
nodes.forEach((node) => this.visit(node));
}
visitElement(element) {
const elementIdentifier = this.elementOrTemplateToIdentifier(element);
if (elementIdentifier !== null) {
this.identifiers.add(elementIdentifier);
}
this.visitAll(element.references);
this.visitAll(element.inputs);
this.visitAll(element.attributes);
this.visitAll(element.children);
this.visitAll(element.outputs);
}
visitTemplate(template) {
const templateIdentifier = this.elementOrTemplateToIdentifier(template);
if (templateIdentifier !== null) {
this.identifiers.add(templateIdentifier);
}
this.visitAll(template.variables);
this.visitAll(template.attributes);
this.visitAll(template.templateAttrs);
this.visitAll(template.children);
this.visitAll(template.references);
}
visitBoundAttribute(attribute) {
if (attribute.valueSpan === void 0) {
return;
}
const { identifiers, errors } = ExpressionVisitor.getIdentifiers(attribute.value, attribute.valueSpan.toString(), attribute.valueSpan.start.offset, this.boundTemplate, this.targetToIdentifier.bind(this));
identifiers.forEach((id) => this.identifiers.add(id));
this.errors.push(...errors);
}
visitBoundEvent(attribute) {
this.visitExpression(attribute.handler);
}
visitBoundText(text) {
this.visitExpression(text.value);
}
visitReference(reference) {
const referenceIdentifier = this.targetToIdentifier(reference);
if (referenceIdentifier === null) {
return;
}
this.identifiers.add(referenceIdentifier);
}
visitVariable(variable) {
const variableIdentifier = this.targetToIdentifier(variable);
if (variableIdentifier === null) {
return;
}
this.identifiers.add(variableIdentifier);
}
visitDeferredBlock(deferred) {
deferred.visitAll(this);
}
visitDeferredBlockPlaceholder(block) {
this.visitAll(block.children);
}
visitDeferredBlockError(block) {
this.visitAll(block.children);
}
visitDeferredBlockLoading(block) {
this.visitAll(block.children);
}
visitDeferredTrigger(trigger) {
if (trigger instanceof TmplAstBoundDeferredTrigger) {
this.visitExpression(trigger.value);
}
}
visitSwitchBlock(block) {
this.visitExpression(block.expression);
this.visitAll(block.cases);
}
visitSwitchBlockCase(block) {
block.expression && this.visitExpression(block.expression);
this.visitAll(block.children);
}
visitForLoopBlock(block) {
var _a;
block.item.visit(this);
this.visitAll(Object.values(block.contextVariables));
this.visitExpression(block.expression);
this.visitAll(block.children);
(_a = block.empty) == null ? void 0 : _a.visit(this);
}
visitForLoopBlockEmpty(block) {
this.visitAll(block.children);
}
visitIfBlock(block) {
this.visitAll(block.branches);
}
visitIfBlockBranch(block) {
var _a;
block.expression && this.visitExpression(block.expression);
(_a = block.expressionAlias) == null ? void 0 : _a.visit(this);
this.visitAll(block.children);
}
elementOrTemplateToIdentifier(node) {
var _a;
if (this.elementAndTemplateIdentifierCache.has(node)) {
return this.elementAndTemplateIdentifierCache.get(node);
}
let name;
let kind;
if (node instanceof TmplAstTemplate) {
name = (_a = node.tagName) != null ? _a : "ng-template";
kind = IdentifierKind.Template;
} else {
name = node.name;
kind = IdentifierKind.Element;
}
if (name.startsWith(":")) {
name = name.split(":").pop();
}
const sourceSpan = node.startSourceSpan;
const start = this.getStartLocation(name, sourceSpan);
if (start === null) {
return null;
}
const absoluteSpan = new AbsoluteSourceSpan(start, start + name.length);
const attributes = node.attributes.map(({ name: name2, sourceSpan: sourceSpan2 }) => {
return {
name: name2,
span: new AbsoluteSourceSpan(sourceSpan2.start.offset, sourceSpan2.end.offset),
kind: IdentifierKind.Attribute
};
});
const usedDirectives = this.boundTemplate.getDirectivesOfNode(node) || [];
const identifier = {
name,
span: absoluteSpan,
kind,
attributes: new Set(attributes),
usedDirectives: new Set(usedDirectives.map((dir) => {
return {
node: dir.ref.node,
selector: dir.selector
};
}))
};
this.elementAndTemplateIdentifierCache.set(node, identifier);
return identifier;
}
targetToIdentifier(node) {
if (this.targetIdentifierCache.has(node)) {
return this.targetIdentifierCache.get(node);
}
const { name, sourceSpan } = node;
const start = this.getStartLocation(name, sourceSpan);
if (start === null) {
return null;
}
const span = new AbsoluteSourceSpan(start, start + name.length);
let identifier;
if (node instanceof TmplAstReference) {
const refTarget = this.boundTemplate.getReferenceTarget(node);
let target = null;
if (refTarget) {
let node2 = null;
let directive = null;
if (refTarget instanceof TmplAstElement || refTarget instanceof TmplAstTemplate) {
node2 = this.elementOrTemplateToIdentifier(refTarget);
} else {
node2 = this.elementOrTemplateToIdentifier(refTarget.node);
directive = refTarget.directive.ref.node;
}
if (node2 === null) {
return null;
}
target = {
node: node2,
directive
};
}
identifier = {
name,
span,
kind: IdentifierKind.Reference,
target
};
} else {
identifier = {
name,
span,
kind: IdentifierKind.Variable
};
}
this.targetIdentifierCache.set(node, identifier);
return identifier;
}
getStartLocation(name, context) {
const localStr = context.toString();
if (!localStr.includes(name)) {
this.errors.push(new Error(`Impossible state: "${name}" not found in "${localStr}"`));
return null;
}
return context.start.offset + localStr.indexOf(name);
}
visitExpression(ast) {
if (ast instanceof ASTWithSource && ast.source !== null) {
const targetToIdentifier = this.targetToIdentifier.bind(this);
const absoluteOffset = ast.sourceSpan.start;
const { identifiers, errors } = ExpressionVisitor.getIdentifiers(ast, ast.source, absoluteOffset, this.boundTemplate, targetToIdentifier);
identifiers.forEach((id) => this.identifiers.add(id));
this.errors.push(...errors);
}
}
};
function getTemplateIdentifiers(boundTemplate) {
const visitor = new TemplateVisitor(boundTemplate);
if (boundTemplate.target.template !== void 0) {
visitor.visitAll(boundTemplate.target.template);
}
return { identifiers: visitor.identifiers, errors: visitor.errors };
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/indexer/src/transform.mjs
function generateAnalysis(context) {
const analysis = /* @__PURE__ */ new Map();
context.components.forEach(({ declaration, selector, boundTemplate, templateMeta }) => {
const name = declaration.name.getText();
const usedComponents = /* @__PURE__ */ new Set();
const usedDirs = boundTemplate.getUsedDirectives();
usedDirs.forEach((dir) => {
if (dir.isComponent) {
usedComponents.add(dir.ref.node);
}
});
const componentFile = new ParseSourceFile(declaration.getSourceFile().getFullText(), declaration.getSourceFile().fileName);
let templateFile;
if (templateMeta.isInline) {
templateFile = componentFile;
} else {
templateFile = templateMeta.file;
}
const { identifiers, errors } = getTemplateIdentifiers(boundTemplate);
analysis.set(declaration, {
name,
selector,
file: componentFile,
template: {
identifiers,
usedComponents,
isInline: templateMeta.isInline,
file: templateFile
},
errors
});
});
return analysis;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/metadata/src/ng_module_index.mjs
var NgModuleIndexImpl = class {
constructor(metaReader, localReader) {
this.metaReader = metaReader;
this.localReader = localReader;
this.ngModuleAuthoritativeReference = /* @__PURE__ */ new Map();
this.typeToExportingModules = /* @__PURE__ */ new Map();
this.indexed = false;
}
updateWith(cache, key, elem) {
if (cache.has(key)) {
cache.get(key).add(elem);
} else {
const set = /* @__PURE__ */ new Set();
set.add(elem);
cache.set(key, set);
}
}
index() {
const seenTypesWithReexports = /* @__PURE__ */ new Map();
const locallyDeclaredDirsAndNgModules = [
...this.localReader.getKnown(MetaKind.NgModule),
...this.localReader.getKnown(MetaKind.Directive)
];
for (const decl of locallyDeclaredDirsAndNgModules) {
this.indexTrait(new Reference(decl), seenTypesWithReexports);
}
this.indexed = true;
}
indexTrait(ref, seenTypesWithReexports) {
var _a, _b, _c;
if (seenTypesWithReexports.has(ref.node)) {
return;
}
seenTypesWithReexports.set(ref.node, /* @__PURE__ */ new Set());
const meta = (_a = this.metaReader.getDirectiveMetadata(ref)) != null ? _a : this.metaReader.getNgModuleMetadata(ref);
if (meta === null) {
return;
}
if (meta.imports !== null) {
for (const childRef of meta.imports) {
this.indexTrait(childRef, seenTypesWithReexports);
}
}
if (meta.kind === MetaKind.NgModule) {
if (!this.ngModuleAuthoritativeReference.has(ref.node)) {
this.ngModuleAuthoritativeReference.set(ref.node, ref);
}
for (const childRef of meta.exports) {
this.indexTrait(childRef, seenTypesWithReexports);
const childMeta = (_c = (_b = this.metaReader.getDirectiveMetadata(childRef)) != null ? _b : this.metaReader.getPipeMetadata(childRef)) != null ? _c : this.metaReader.getNgModuleMetadata(childRef);
if (childMeta === null) {
continue;
}
switch (childMeta.kind) {
case MetaKind.Directive:
case MetaKind.Pipe:
this.updateWith(this.typeToExportingModules, childRef.node, ref.node);
this.updateWith(seenTypesWithReexports, ref.node, childRef.node);
break;
case MetaKind.NgModule:
if (seenTypesWithReexports.has(childRef.node)) {
for (const reexported of seenTypesWithReexports.get(childRef.node)) {
this.updateWith(this.typeToExportingModules, reexported, ref.node);
this.updateWith(seenTypesWithReexports, ref.node, reexported);
}
}
break;
}
}
}
}
getNgModulesExporting(directiveOrPipe) {
if (!this.indexed) {
this.index();
}
if (!this.typeToExportingModules.has(directiveOrPipe)) {
return [];
}
const refs = [];
for (const ngModule of this.typeToExportingModules.get(directiveOrPipe)) {
if (this.ngModuleAuthoritativeReference.has(ngModule)) {
refs.push(this.ngModuleAuthoritativeReference.get(ngModule));
}
}
return refs;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/resource/src/loader.mjs
import ts14 from "typescript";
var CSS_PREPROCESSOR_EXT = /(\.scss|\.sass|\.less|\.styl)$/;
var RESOURCE_MARKER = ".$ngresource$";
var RESOURCE_MARKER_TS = RESOURCE_MARKER + ".ts";
var AdapterResourceLoader = class {
constructor(adapter, options) {
this.adapter = adapter;
this.options = options;
this.cache = /* @__PURE__ */ new Map();
this.fetching = /* @__PURE__ */ new Map();
this.lookupResolutionHost = createLookupResolutionHost(this.adapter);
this.canPreload = !!this.adapter.readResource;
this.canPreprocess = !!this.adapter.transformResource;
}
resolve(url, fromFile) {
let resolvedUrl = null;
if (this.adapter.resourceNameToFileName) {
resolvedUrl = this.adapter.resourceNameToFileName(url, fromFile, (url2, fromFile2) => this.fallbackResolve(url2, fromFile2));
} else {
resolvedUrl = this.fallbackResolve(url, fromFile);
}
if (resolvedUrl === null) {
throw new Error(`HostResourceResolver: could not resolve ${url} in context of ${fromFile})`);
}
return resolvedUrl;
}
preload(resolvedUrl, context) {
if (!this.adapter.readResource) {
throw new Error("HostResourceLoader: the CompilerHost provided does not support pre-loading resources.");
}
if (this.cache.has(resolvedUrl)) {
return void 0;
} else if (this.fetching.has(resolvedUrl)) {
return this.fetching.get(resolvedUrl);
}
let result = this.adapter.readResource(resolvedUrl);
if (this.adapter.transformResource && context.type === "style") {
const resourceContext = {
type: "style",
containingFile: context.containingFile,
resourceFile: resolvedUrl
};
result = Promise.resolve(result).then(async (str) => {
const transformResult = await this.adapter.transformResource(str, resourceContext);
return transformResult === null ? str : transformResult.content;
});
}
if (typeof result === "string") {
this.cache.set(resolvedUrl, result);
return void 0;
} else {
const fetchCompletion = result.then((str) => {
this.fetching.delete(resolvedUrl);
this.cache.set(resolvedUrl, str);
});
this.fetching.set(resolvedUrl, fetchCompletion);
return fetchCompletion;
}
}
async preprocessInline(data, context) {
if (!this.adapter.transformResource || context.type !== "style") {
return data;
}
const transformResult = await this.adapter.transformResource(data, { type: "style", containingFile: context.containingFile, resourceFile: null });
if (transformResult === null) {
return data;
}
return transformResult.content;
}
load(resolvedUrl) {
if (this.cache.has(resolvedUrl)) {
return this.cache.get(resolvedUrl);
}
const result = this.adapter.readResource ? this.adapter.readResource(resolvedUrl) : this.adapter.readFile(resolvedUrl);
if (typeof result !== "string") {
throw new Error(`HostResourceLoader: loader(${resolvedUrl}) returned a Promise`);
}
this.cache.set(resolvedUrl, result);
return result;
}
invalidate() {
this.cache.clear();
}
fallbackResolve(url, fromFile) {
let candidateLocations;
if (url.startsWith("/")) {
candidateLocations = this.getRootedCandidateLocations(url);
} else {
if (!url.startsWith(".")) {
url = `./${url}`;
}
candidateLocations = this.getResolvedCandidateLocations(url, fromFile);
}
for (const candidate of candidateLocations) {
if (this.adapter.fileExists(candidate)) {
return candidate;
} else if (CSS_PREPROCESSOR_EXT.test(candidate)) {
const cssFallbackUrl = candidate.replace(CSS_PREPROCESSOR_EXT, ".css");
if (this.adapter.fileExists(cssFallbackUrl)) {
return cssFallbackUrl;
}
}
}
return null;
}
getRootedCandidateLocations(url) {
const segment = "." + url;
return this.adapter.rootDirs.map((rootDir) => join(rootDir, segment));
}
getResolvedCandidateLocations(url, fromFile) {
const failedLookup = ts14.resolveModuleName(url + RESOURCE_MARKER, fromFile, this.options, this.lookupResolutionHost);
if (failedLookup.failedLookupLocations === void 0) {
throw new Error(`Internal error: expected to find failedLookupLocations during resolution of resource '${url}' in context of ${fromFile}`);
}
return failedLookup.failedLookupLocations.filter((candidate) => candidate.endsWith(RESOURCE_MARKER_TS)).map((candidate) => candidate.slice(0, -RESOURCE_MARKER_TS.length));
}
};
function createLookupResolutionHost(adapter) {
var _a, _b, _c;
return {
directoryExists(directoryName) {
if (directoryName.includes(RESOURCE_MARKER)) {
return false;
} else if (adapter.directoryExists !== void 0) {
return adapter.directoryExists(directoryName);
} else {
return true;
}
},
fileExists(fileName) {
if (fileName.includes(RESOURCE_MARKER)) {
return false;
} else {
return adapter.fileExists(fileName);
}
},
readFile: adapter.readFile.bind(adapter),
getCurrentDirectory: adapter.getCurrentDirectory.bind(adapter),
getDirectories: (_a = adapter.getDirectories) == null ? void 0 : _a.bind(adapter),
realpath: (_b = adapter.realpath) == null ? void 0 : _b.bind(adapter),
trace: (_c = adapter.trace) == null ? void 0 : _c.bind(adapter),
useCaseSensitiveFileNames: typeof adapter.useCaseSensitiveFileNames === "function" ? adapter.useCaseSensitiveFileNames.bind(adapter) : adapter.useCaseSensitiveFileNames
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/scope/src/standalone.mjs
var StandaloneComponentScopeReader = class {
constructor(metaReader, localModuleReader, dtsModuleReader) {
this.metaReader = metaReader;
this.localModuleReader = localModuleReader;
this.dtsModuleReader = dtsModuleReader;
this.cache = /* @__PURE__ */ new Map();
}
getScopeForComponent(clazz) {
var _a;
if (!this.cache.has(clazz)) {
const clazzRef = new Reference(clazz);
const clazzMeta = this.metaReader.getDirectiveMetadata(clazzRef);
if (clazzMeta === null || !clazzMeta.isComponent || !clazzMeta.isStandalone) {
this.cache.set(clazz, null);
return null;
}
const dependencies = /* @__PURE__ */ new Set([clazzMeta]);
const deferredDependencies = /* @__PURE__ */ new Set();
const seen = /* @__PURE__ */ new Set([clazz]);
let isPoisoned = clazzMeta.isPoisoned;
if (clazzMeta.imports !== null) {
for (const ref of clazzMeta.imports) {
if (seen.has(ref.node)) {
continue;
}
seen.add(ref.node);
const dirMeta = this.metaReader.getDirectiveMetadata(ref);
if (dirMeta !== null) {
dependencies.add({ ...dirMeta, ref });
isPoisoned = isPoisoned || dirMeta.isPoisoned || !dirMeta.isStandalone;
continue;
}
const pipeMeta = this.metaReader.getPipeMetadata(ref);
if (pipeMeta !== null) {
dependencies.add({ ...pipeMeta, ref });
isPoisoned = isPoisoned || !pipeMeta.isStandalone;
continue;
}
const ngModuleMeta = this.metaReader.getNgModuleMetadata(ref);
if (ngModuleMeta !== null) {
dependencies.add({ ...ngModuleMeta, ref });
let ngModuleScope;
if (ref.node.getSourceFile().isDeclarationFile) {
ngModuleScope = this.dtsModuleReader.resolve(ref);
} else {
ngModuleScope = this.localModuleReader.getScopeOfModule(ref.node);
}
if (ngModuleScope === null) {
isPoisoned = true;
continue;
}
isPoisoned = isPoisoned || ngModuleScope.exported.isPoisoned;
for (const dep of ngModuleScope.exported.dependencies) {
if (!seen.has(dep.ref.node)) {
seen.add(dep.ref.node);
dependencies.add(dep);
}
}
continue;
}
isPoisoned = true;
}
}
if (clazzMeta.deferredImports !== null) {
for (const ref of clazzMeta.deferredImports) {
const dirMeta = this.metaReader.getDirectiveMetadata(ref);
if (dirMeta !== null) {
deferredDependencies.add({ ...dirMeta, ref, isExplicitlyDeferred: true });
isPoisoned = isPoisoned || dirMeta.isPoisoned || !dirMeta.isStandalone;
continue;
}
const pipeMeta = this.metaReader.getPipeMetadata(ref);
if (pipeMeta !== null) {
deferredDependencies.add({ ...pipeMeta, ref, isExplicitlyDeferred: true });
isPoisoned = isPoisoned || !pipeMeta.isStandalone;
continue;
}
}
}
this.cache.set(clazz, {
kind: ComponentScopeKind.Standalone,
component: clazz,
dependencies: Array.from(dependencies),
deferredDependencies: Array.from(deferredDependencies),
isPoisoned,
schemas: (_a = clazzMeta.schemas) != null ? _a : []
});
}
return this.cache.get(clazz);
}
getRemoteScope() {
return null;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/checker.mjs
import { CssSelector as CssSelector2, DomElementSchemaRegistry as DomElementSchemaRegistry2, ExternalExpr as ExternalExpr2, WrappedNodeExpr as WrappedNodeExpr2 } from "@angular/compiler";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/diagnostics/src/diagnostic.mjs
import ts15 from "typescript";
function makeTemplateDiagnostic(templateId, mapping, span, category, code, messageText, relatedMessages) {
var _a;
if (mapping.type === "direct") {
let relatedInformation = void 0;
if (relatedMessages !== void 0) {
relatedInformation = [];
for (const relatedMessage of relatedMessages) {
relatedInformation.push({
category: ts15.DiagnosticCategory.Message,
code: 0,
file: relatedMessage.sourceFile,
start: relatedMessage.start,
length: relatedMessage.end - relatedMessage.start,
messageText: relatedMessage.text
});
}
}
return {
source: "ngtsc",
code,
category,
messageText,
file: mapping.node.getSourceFile(),
componentFile: mapping.node.getSourceFile(),
templateId,
start: span.start.offset,
length: span.end.offset - span.start.offset,
relatedInformation
};
} else if (mapping.type === "indirect" || mapping.type === "external") {
const componentSf = mapping.componentClass.getSourceFile();
const componentName = mapping.componentClass.name.text;
const fileName = mapping.type === "indirect" ? `${componentSf.fileName} (${componentName} template)` : mapping.templateUrl;
let relatedInformation = [];
if (relatedMessages !== void 0) {
for (const relatedMessage of relatedMessages) {
relatedInformation.push({
category: ts15.DiagnosticCategory.Message,
code: 0,
file: relatedMessage.sourceFile,
start: relatedMessage.start,
length: relatedMessage.end - relatedMessage.start,
messageText: relatedMessage.text
});
}
}
let sf;
try {
sf = getParsedTemplateSourceFile(fileName, mapping);
} catch (e) {
const failureChain = makeDiagnosticChain(`Failed to report an error in '${fileName}' at ${span.start.line + 1}:${span.start.col + 1}`, [
makeDiagnosticChain((_a = e == null ? void 0 : e.stack) != null ? _a : `${e}`)
]);
return {
source: "ngtsc",
category,
code,
messageText: addDiagnosticChain(messageText, [failureChain]),
file: componentSf,
componentFile: componentSf,
templateId,
start: mapping.node.getStart(),
length: mapping.node.getEnd() - mapping.node.getStart(),
relatedInformation
};
}
relatedInformation.push({
category: ts15.DiagnosticCategory.Message,
code: 0,
file: componentSf,
start: mapping.node.getStart(),
length: mapping.node.getEnd() - mapping.node.getStart(),
messageText: `Error occurs in the template of component ${componentName}.`
});
return {
source: "ngtsc",
category,
code,
messageText,
file: sf,
componentFile: componentSf,
templateId,
start: span.start.offset,
length: span.end.offset - span.start.offset,
relatedInformation
};
} else {
throw new Error(`Unexpected source mapping type: ${mapping.type}`);
}
}
var TemplateSourceFile = Symbol("TemplateSourceFile");
function getParsedTemplateSourceFile(fileName, mapping) {
if (mapping[TemplateSourceFile] === void 0) {
mapping[TemplateSourceFile] = parseTemplateAsSourceFile(fileName, mapping.template);
}
return mapping[TemplateSourceFile];
}
var parseTemplateAsSourceFileForTest = null;
function parseTemplateAsSourceFile(fileName, template) {
if (parseTemplateAsSourceFileForTest !== null) {
return parseTemplateAsSourceFileForTest(fileName, template);
}
return ts15.createSourceFile(fileName, template, ts15.ScriptTarget.Latest, false, ts15.ScriptKind.JSX);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/diagnostics/src/id.mjs
var TEMPLATE_ID = Symbol("ngTemplateId");
var NEXT_TEMPLATE_ID = Symbol("ngNextTemplateId");
function getTemplateId(clazz) {
const node = clazz;
if (node[TEMPLATE_ID] === void 0) {
node[TEMPLATE_ID] = allocateTemplateId(node.getSourceFile());
}
return node[TEMPLATE_ID];
}
function allocateTemplateId(sf) {
if (sf[NEXT_TEMPLATE_ID] === void 0) {
sf[NEXT_TEMPLATE_ID] = 1;
}
return `tcb${sf[NEXT_TEMPLATE_ID]++}`;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/completion.mjs
import { EmptyExpr, ImplicitReceiver as ImplicitReceiver2, PropertyRead as PropertyRead2, PropertyWrite as PropertyWrite2, SafePropertyRead, TmplAstReference as TmplAstReference2, TmplAstTextAttribute } from "@angular/compiler";
import ts17 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/comments.mjs
import { AbsoluteSourceSpan as AbsoluteSourceSpan2 } from "@angular/compiler";
import ts16 from "typescript";
var parseSpanComment = /^(\d+),(\d+)$/;
function readSpanComment(node, sourceFile = node.getSourceFile()) {
return ts16.forEachTrailingCommentRange(sourceFile.text, node.getEnd(), (pos, end, kind) => {
if (kind !== ts16.SyntaxKind.MultiLineCommentTrivia) {
return null;
}
const commentText = sourceFile.text.substring(pos + 2, end - 2);
const match = commentText.match(parseSpanComment);
if (match === null) {
return null;
}
return new AbsoluteSourceSpan2(+match[1], +match[2]);
}) || null;
}
var CommentTriviaType;
(function(CommentTriviaType2) {
CommentTriviaType2["DIAGNOSTIC"] = "D";
CommentTriviaType2["EXPRESSION_TYPE_IDENTIFIER"] = "T";
})(CommentTriviaType || (CommentTriviaType = {}));
var ExpressionIdentifier;
(function(ExpressionIdentifier2) {
ExpressionIdentifier2["DIRECTIVE"] = "DIR";
ExpressionIdentifier2["COMPONENT_COMPLETION"] = "COMPCOMP";
ExpressionIdentifier2["EVENT_PARAMETER"] = "EP";
ExpressionIdentifier2["VARIABLE_AS_EXPRESSION"] = "VAE";
})(ExpressionIdentifier || (ExpressionIdentifier = {}));
function addExpressionIdentifier(node, identifier) {
ts16.addSyntheticTrailingComment(
node,
ts16.SyntaxKind.MultiLineCommentTrivia,
`${CommentTriviaType.EXPRESSION_TYPE_IDENTIFIER}:${identifier}`,
false
);
}
var IGNORE_FOR_DIAGNOSTICS_MARKER = `${CommentTriviaType.DIAGNOSTIC}:ignore`;
function markIgnoreDiagnostics(node) {
ts16.addSyntheticTrailingComment(
node,
ts16.SyntaxKind.MultiLineCommentTrivia,
IGNORE_FOR_DIAGNOSTICS_MARKER,
false
);
}
function hasIgnoreForDiagnosticsMarker(node, sourceFile) {
return ts16.forEachTrailingCommentRange(sourceFile.text, node.getEnd(), (pos, end, kind) => {
if (kind !== ts16.SyntaxKind.MultiLineCommentTrivia) {
return null;
}
const commentText = sourceFile.text.substring(pos + 2, end - 2);
return commentText === IGNORE_FOR_DIAGNOSTICS_MARKER;
}) === true;
}
function makeRecursiveVisitor(visitor) {
function recursiveVisitor(node) {
const res = visitor(node);
return res !== null ? res : node.forEachChild(recursiveVisitor);
}
return recursiveVisitor;
}
function getSpanFromOptions(opts) {
let withSpan = null;
if (opts.withSpan !== void 0) {
if (opts.withSpan instanceof AbsoluteSourceSpan2) {
withSpan = opts.withSpan;
} else {
withSpan = { start: opts.withSpan.start.offset, end: opts.withSpan.end.offset };
}
}
return withSpan;
}
function findFirstMatchingNode(tcb, opts) {
var _a;
const withSpan = getSpanFromOptions(opts);
const withExpressionIdentifier = opts.withExpressionIdentifier;
const sf = tcb.getSourceFile();
const visitor = makeRecursiveVisitor((node) => {
if (!opts.filter(node)) {
return null;
}
if (withSpan !== null) {
const comment = readSpanComment(node, sf);
if (comment === null || withSpan.start !== comment.start || withSpan.end !== comment.end) {
return null;
}
}
if (withExpressionIdentifier !== void 0 && !hasExpressionIdentifier(sf, node, withExpressionIdentifier)) {
return null;
}
return node;
});
return (_a = tcb.forEachChild(visitor)) != null ? _a : null;
}
function findAllMatchingNodes(tcb, opts) {
const withSpan = getSpanFromOptions(opts);
const withExpressionIdentifier = opts.withExpressionIdentifier;
const results = [];
const stack = [tcb];
const sf = tcb.getSourceFile();
while (stack.length > 0) {
const node = stack.pop();
if (!opts.filter(node)) {
stack.push(...node.getChildren());
continue;
}
if (withSpan !== null) {
const comment = readSpanComment(node, sf);
if (comment === null || withSpan.start !== comment.start || withSpan.end !== comment.end) {
stack.push(...node.getChildren());
continue;
}
}
if (withExpressionIdentifier !== void 0 && !hasExpressionIdentifier(sf, node, withExpressionIdentifier)) {
continue;
}
results.push(node);
}
return results;
}
function hasExpressionIdentifier(sourceFile, node, identifier) {
return ts16.forEachTrailingCommentRange(sourceFile.text, node.getEnd(), (pos, end, kind) => {
if (kind !== ts16.SyntaxKind.MultiLineCommentTrivia) {
return false;
}
const commentText = sourceFile.text.substring(pos + 2, end - 2);
return commentText === `${CommentTriviaType.EXPRESSION_TYPE_IDENTIFIER}:${identifier}`;
}) || false;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/completion.mjs
var CompletionEngine = class {
constructor(tcb, data, tcbPath, tcbIsShim) {
this.tcb = tcb;
this.data = data;
this.tcbPath = tcbPath;
this.tcbIsShim = tcbIsShim;
this.templateContextCache = /* @__PURE__ */ new Map();
this.expressionCompletionCache = /* @__PURE__ */ new Map();
const globalRead = findFirstMatchingNode(this.tcb, {
filter: ts17.isPropertyAccessExpression,
withExpressionIdentifier: ExpressionIdentifier.COMPONENT_COMPLETION
});
if (globalRead !== null) {
this.componentContext = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: globalRead.name.getStart()
};
} else {
this.componentContext = null;
}
}
getGlobalCompletions(context, node) {
if (this.componentContext === null) {
return null;
}
const templateContext = this.getTemplateContextCompletions(context);
if (templateContext === null) {
return null;
}
let nodeContext = null;
if (node instanceof EmptyExpr) {
const nodeLocation = findFirstMatchingNode(this.tcb, {
filter: ts17.isIdentifier,
withSpan: node.sourceSpan
});
if (nodeLocation !== null) {
nodeContext = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: nodeLocation.getStart()
};
}
}
if (node instanceof PropertyRead2 && node.receiver instanceof ImplicitReceiver2) {
const nodeLocation = findFirstMatchingNode(this.tcb, {
filter: ts17.isPropertyAccessExpression,
withSpan: node.sourceSpan
});
if (nodeLocation) {
nodeContext = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: nodeLocation.getStart()
};
}
}
return {
componentContext: this.componentContext,
templateContext,
nodeContext
};
}
getExpressionCompletionLocation(expr) {
if (this.expressionCompletionCache.has(expr)) {
return this.expressionCompletionCache.get(expr);
}
let tsExpr = null;
if (expr instanceof PropertyRead2 || expr instanceof PropertyWrite2) {
tsExpr = findFirstMatchingNode(this.tcb, {
filter: ts17.isPropertyAccessExpression,
withSpan: expr.nameSpan
});
} else if (expr instanceof SafePropertyRead) {
const ternaryExpr = findFirstMatchingNode(this.tcb, {
filter: ts17.isParenthesizedExpression,
withSpan: expr.sourceSpan
});
if (ternaryExpr === null || !ts17.isConditionalExpression(ternaryExpr.expression)) {
return null;
}
const whenTrue = ternaryExpr.expression.whenTrue;
if (ts17.isPropertyAccessExpression(whenTrue)) {
tsExpr = whenTrue;
} else if (ts17.isCallExpression(whenTrue) && ts17.isPropertyAccessExpression(whenTrue.expression)) {
tsExpr = whenTrue.expression;
}
}
if (tsExpr === null) {
return null;
}
const res = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: tsExpr.name.getEnd()
};
this.expressionCompletionCache.set(expr, res);
return res;
}
getLiteralCompletionLocation(expr) {
if (this.expressionCompletionCache.has(expr)) {
return this.expressionCompletionCache.get(expr);
}
let tsExpr = null;
if (expr instanceof TmplAstTextAttribute) {
const strNode = findFirstMatchingNode(this.tcb, {
filter: ts17.isParenthesizedExpression,
withSpan: expr.sourceSpan
});
if (strNode !== null && ts17.isStringLiteral(strNode.expression)) {
tsExpr = strNode.expression;
}
} else {
tsExpr = findFirstMatchingNode(this.tcb, {
filter: (n) => ts17.isStringLiteral(n) || ts17.isNumericLiteral(n),
withSpan: expr.sourceSpan
});
}
if (tsExpr === null) {
return null;
}
let positionInShimFile = tsExpr.getEnd();
if (ts17.isStringLiteral(tsExpr)) {
positionInShimFile -= 1;
}
const res = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: positionInShimFile
};
this.expressionCompletionCache.set(expr, res);
return res;
}
getTemplateContextCompletions(context) {
if (this.templateContextCache.has(context)) {
return this.templateContextCache.get(context);
}
const templateContext = /* @__PURE__ */ new Map();
for (const node of this.data.boundTarget.getEntitiesInScope(context)) {
if (node instanceof TmplAstReference2) {
templateContext.set(node.name, {
kind: CompletionKind.Reference,
node
});
} else {
templateContext.set(node.name, {
kind: CompletionKind.Variable,
node
});
}
}
this.templateContextCache.set(context, templateContext);
return templateContext;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/context.mjs
import ts30 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/dom.mjs
import { DomElementSchemaRegistry } from "@angular/compiler";
import ts18 from "typescript";
var REGISTRY = new DomElementSchemaRegistry();
var REMOVE_XHTML_REGEX = /^:xhtml:/;
var RegistryDomSchemaChecker = class {
get diagnostics() {
return this._diagnostics;
}
constructor(resolver) {
this.resolver = resolver;
this._diagnostics = [];
}
checkElement(id, element, schemas, hostIsStandalone) {
const name = element.name.replace(REMOVE_XHTML_REGEX, "");
if (!REGISTRY.hasElement(name, schemas)) {
const mapping = this.resolver.getSourceMapping(id);
const schemas2 = `'${hostIsStandalone ? "@Component" : "@NgModule"}.schemas'`;
let errorMsg = `'${name}' is not a known element:
`;
errorMsg += `1. If '${name}' is an Angular component, then verify that it is ${hostIsStandalone ? "included in the '@Component.imports' of this component" : "part of this module"}.
`;
if (name.indexOf("-") > -1) {
errorMsg += `2. If '${name}' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the ${schemas2} of this component to suppress this message.`;
} else {
errorMsg += `2. To allow any element add 'NO_ERRORS_SCHEMA' to the ${schemas2} of this component.`;
}
const diag = makeTemplateDiagnostic(id, mapping, element.startSourceSpan, ts18.DiagnosticCategory.Error, ngErrorCode(ErrorCode.SCHEMA_INVALID_ELEMENT), errorMsg);
this._diagnostics.push(diag);
}
}
checkProperty(id, element, name, span, schemas, hostIsStandalone) {
if (!REGISTRY.hasProperty(element.name, name, schemas)) {
const mapping = this.resolver.getSourceMapping(id);
const decorator = hostIsStandalone ? "@Component" : "@NgModule";
const schemas2 = `'${decorator}.schemas'`;
let errorMsg = `Can't bind to '${name}' since it isn't a known property of '${element.name}'.`;
if (element.name.startsWith("ng-")) {
errorMsg += `
1. If '${name}' is an Angular directive, then add 'CommonModule' to the '${decorator}.imports' of this component.
2. To allow any property add 'NO_ERRORS_SCHEMA' to the ${schemas2} of this component.`;
} else if (element.name.indexOf("-") > -1) {
errorMsg += `
1. If '${element.name}' is an Angular component and it has '${name}' input, then verify that it is ${hostIsStandalone ? "included in the '@Component.imports' of this component" : "part of this module"}.
2. If '${element.name}' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the ${schemas2} of this component to suppress this message.
3. To allow any property add 'NO_ERRORS_SCHEMA' to the ${schemas2} of this component.`;
}
const diag = makeTemplateDiagnostic(id, mapping, span, ts18.DiagnosticCategory.Error, ngErrorCode(ErrorCode.SCHEMA_INVALID_ATTRIBUTE), errorMsg);
this._diagnostics.push(diag);
}
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/environment.mjs
import ts23 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/reference_emit_environment.mjs
import { ExpressionType, ExternalExpr, TypeModifier } from "@angular/compiler";
var ReferenceEmitEnvironment = class {
constructor(importManager, refEmitter, reflector, contextFile) {
this.importManager = importManager;
this.refEmitter = refEmitter;
this.reflector = reflector;
this.contextFile = contextFile;
}
canReferenceType(ref, flags = ImportFlags.NoAliasing | ImportFlags.AllowTypeImports | ImportFlags.AllowRelativeDtsImports) {
const result = this.refEmitter.emit(ref, this.contextFile, flags);
return result.kind === 0;
}
referenceType(ref, flags = ImportFlags.NoAliasing | ImportFlags.AllowTypeImports | ImportFlags.AllowRelativeDtsImports) {
const ngExpr = this.refEmitter.emit(ref, this.contextFile, flags);
assertSuccessfulReferenceEmit(ngExpr, this.contextFile, "symbol");
return translateType(new ExpressionType(ngExpr.expression), this.contextFile, this.reflector, this.refEmitter, this.importManager);
}
referenceExternalSymbol(moduleName, name) {
const external = new ExternalExpr({ moduleName, name });
return translateExpression(external, this.importManager);
}
referenceExternalType(moduleName, name, typeParams) {
const external = new ExternalExpr({ moduleName, name });
return translateType(new ExpressionType(external, TypeModifier.None, typeParams), this.contextFile, this.reflector, this.refEmitter, this.importManager);
}
referenceTransplantedType(type) {
return translateType(type, this.contextFile, this.reflector, this.refEmitter, this.importManager);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/ts_util.mjs
import ts19 from "typescript";
var SAFE_TO_CAST_WITHOUT_PARENS = /* @__PURE__ */ new Set([
ts19.SyntaxKind.ParenthesizedExpression,
ts19.SyntaxKind.Identifier,
ts19.SyntaxKind.CallExpression,
ts19.SyntaxKind.NonNullExpression,
ts19.SyntaxKind.ElementAccessExpression,
ts19.SyntaxKind.PropertyAccessExpression,
ts19.SyntaxKind.ArrayLiteralExpression,
ts19.SyntaxKind.ObjectLiteralExpression,
ts19.SyntaxKind.StringLiteral,
ts19.SyntaxKind.NumericLiteral,
ts19.SyntaxKind.TrueKeyword,
ts19.SyntaxKind.FalseKeyword,
ts19.SyntaxKind.NullKeyword,
ts19.SyntaxKind.UndefinedKeyword
]);
function tsCastToAny(expr) {
if (!SAFE_TO_CAST_WITHOUT_PARENS.has(expr.kind)) {
expr = ts19.factory.createParenthesizedExpression(expr);
}
return ts19.factory.createParenthesizedExpression(ts19.factory.createAsExpression(expr, ts19.factory.createKeywordTypeNode(ts19.SyntaxKind.AnyKeyword)));
}
function tsCreateElement(tagName) {
const createElement = ts19.factory.createPropertyAccessExpression(
ts19.factory.createIdentifier("document"),
"createElement"
);
return ts19.factory.createCallExpression(
createElement,
void 0,
[ts19.factory.createStringLiteral(tagName)]
);
}
function tsDeclareVariable(id, type) {
addExpressionIdentifier(type, ExpressionIdentifier.VARIABLE_AS_EXPRESSION);
const initializer = ts19.factory.createAsExpression(ts19.factory.createNonNullExpression(ts19.factory.createNull()), type);
const decl = ts19.factory.createVariableDeclaration(
id,
void 0,
void 0,
initializer
);
return ts19.factory.createVariableStatement(
void 0,
[decl]
);
}
function tsCreateTypeQueryForCoercedInput(typeName, coercedInputName) {
return ts19.factory.createTypeQueryNode(ts19.factory.createQualifiedName(typeName, `ngAcceptInputType_${coercedInputName}`));
}
function tsCreateVariable(id, initializer) {
const decl = ts19.factory.createVariableDeclaration(
id,
void 0,
void 0,
initializer
);
return ts19.factory.createVariableStatement(
void 0,
[decl]
);
}
function tsCallMethod(receiver, methodName, args = []) {
const methodAccess = ts19.factory.createPropertyAccessExpression(receiver, methodName);
return ts19.factory.createCallExpression(
methodAccess,
void 0,
args
);
}
function isAccessExpression(node) {
return ts19.isPropertyAccessExpression(node) || ts19.isElementAccessExpression(node);
}
function tsNumericExpression(value) {
if (value < 0) {
const operand = ts19.factory.createNumericLiteral(Math.abs(value));
return ts19.factory.createPrefixUnaryExpression(ts19.SyntaxKind.MinusToken, operand);
}
return ts19.factory.createNumericLiteral(value);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_constructor.mjs
import { ExpressionType as ExpressionType2, R3Identifiers as R3Identifiers2, WrappedNodeExpr } from "@angular/compiler";
import ts22 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/tcb_util.mjs
import { R3Identifiers } from "@angular/compiler";
import ts21 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_parameter_emitter.mjs
import ts20 from "typescript";
var TypeParameterEmitter = class {
constructor(typeParameters, reflector) {
this.typeParameters = typeParameters;
this.reflector = reflector;
}
canEmit(canEmitReference) {
if (this.typeParameters === void 0) {
return true;
}
return this.typeParameters.every((typeParam) => {
return this.canEmitType(typeParam.constraint, canEmitReference) && this.canEmitType(typeParam.default, canEmitReference);
});
}
canEmitType(type, canEmitReference) {
if (type === void 0) {
return true;
}
return canEmitType(type, (typeReference) => {
const reference = this.resolveTypeReference(typeReference);
if (reference === null) {
return false;
}
if (reference instanceof Reference) {
return canEmitReference(reference);
}
return true;
});
}
emit(emitReference) {
if (this.typeParameters === void 0) {
return void 0;
}
const emitter = new TypeEmitter((type) => this.translateTypeReference(type, emitReference));
return this.typeParameters.map((typeParam) => {
const constraint = typeParam.constraint !== void 0 ? emitter.emitType(typeParam.constraint) : void 0;
const defaultType = typeParam.default !== void 0 ? emitter.emitType(typeParam.default) : void 0;
return ts20.factory.updateTypeParameterDeclaration(typeParam, typeParam.modifiers, typeParam.name, constraint, defaultType);
});
}
resolveTypeReference(type) {
const target = ts20.isIdentifier(type.typeName) ? type.typeName : type.typeName.right;
const declaration = this.reflector.getDeclarationOfIdentifier(target);
if (declaration === null || declaration.node === null) {
return null;
}
if (this.isLocalTypeParameter(declaration.node)) {
return type;
}
let owningModule = null;
if (typeof declaration.viaModule === "string") {
owningModule = {
specifier: declaration.viaModule,
resolutionContext: type.getSourceFile().fileName
};
}
return new Reference(declaration.node, declaration.viaModule === AmbientImport ? AmbientImport : owningModule);
}
translateTypeReference(type, emitReference) {
const reference = this.resolveTypeReference(type);
if (!(reference instanceof Reference)) {
return reference;
}
const typeNode = emitReference(reference);
if (typeNode === null) {
return null;
}
if (!ts20.isTypeReferenceNode(typeNode)) {
throw new Error(`Expected TypeReferenceNode for emitted reference, got ${ts20.SyntaxKind[typeNode.kind]}.`);
}
return typeNode;
}
isLocalTypeParameter(decl) {
return this.typeParameters.some((param) => param === decl);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/tcb_util.mjs
var TCB_FILE_IMPORT_GRAPH_PREPARE_MODULES = [
R3Identifiers.InputSignalBrandWriteType.moduleName
];
var TcbInliningRequirement;
(function(TcbInliningRequirement2) {
TcbInliningRequirement2[TcbInliningRequirement2["MustInline"] = 0] = "MustInline";
TcbInliningRequirement2[TcbInliningRequirement2["ShouldInlineForGenericBounds"] = 1] = "ShouldInlineForGenericBounds";
TcbInliningRequirement2[TcbInliningRequirement2["None"] = 2] = "None";
})(TcbInliningRequirement || (TcbInliningRequirement = {}));
function requiresInlineTypeCheckBlock(ref, env, usedPipes, reflector) {
if (!env.canReferenceType(ref)) {
return TcbInliningRequirement.MustInline;
} else if (!checkIfGenericTypeBoundsCanBeEmitted(ref.node, reflector, env)) {
return TcbInliningRequirement.ShouldInlineForGenericBounds;
} else if (usedPipes.some((pipeRef) => !env.canReferenceType(pipeRef))) {
return TcbInliningRequirement.MustInline;
} else {
return TcbInliningRequirement.None;
}
}
function getTemplateMapping(shimSf, position, resolver, isDiagnosticRequest) {
const node = getTokenAtPosition(shimSf, position);
const sourceLocation = findSourceLocation(node, shimSf, isDiagnosticRequest);
if (sourceLocation === null) {
return null;
}
const mapping = resolver.getSourceMapping(sourceLocation.id);
const span = resolver.toParseSourceSpan(sourceLocation.id, sourceLocation.span);
if (span === null) {
return null;
}
return { sourceLocation, templateSourceMapping: mapping, span };
}
function findTypeCheckBlock(file, id, isDiagnosticRequest) {
for (const stmt of file.statements) {
if (ts21.isFunctionDeclaration(stmt) && getTemplateId2(stmt, file, isDiagnosticRequest) === id) {
return stmt;
}
}
return null;
}
function findSourceLocation(node, sourceFile, isDiagnosticsRequest) {
while (node !== void 0 && !ts21.isFunctionDeclaration(node)) {
if (hasIgnoreForDiagnosticsMarker(node, sourceFile) && isDiagnosticsRequest) {
return null;
}
const span = readSpanComment(node, sourceFile);
if (span !== null) {
const id = getTemplateId2(node, sourceFile, isDiagnosticsRequest);
if (id === null) {
return null;
}
return { id, span };
}
node = node.parent;
}
return null;
}
function getTemplateId2(node, sourceFile, isDiagnosticRequest) {
while (!ts21.isFunctionDeclaration(node)) {
if (hasIgnoreForDiagnosticsMarker(node, sourceFile) && isDiagnosticRequest) {
return null;
}
node = node.parent;
if (node === void 0) {
return null;
}
}
const start = node.getFullStart();
return ts21.forEachLeadingCommentRange(sourceFile.text, start, (pos, end, kind) => {
if (kind !== ts21.SyntaxKind.MultiLineCommentTrivia) {
return null;
}
const commentText = sourceFile.text.substring(pos + 2, end - 2);
return commentText;
}) || null;
}
function ensureTypeCheckFilePreparationImports(env) {
for (const moduleName of TCB_FILE_IMPORT_GRAPH_PREPARE_MODULES) {
env.importManager.generateNamespaceImport(moduleName);
}
}
function checkIfGenericTypeBoundsCanBeEmitted(node, reflector, env) {
const emitter = new TypeParameterEmitter(node.typeParameters, reflector);
return emitter.canEmit((ref) => env.canReferenceType(ref));
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_constructor.mjs
function generateTypeCtorDeclarationFn(env, meta, nodeTypeRef, typeParams) {
const rawTypeArgs = typeParams !== void 0 ? generateGenericArgs(typeParams) : void 0;
const rawType = ts22.factory.createTypeReferenceNode(nodeTypeRef, rawTypeArgs);
const initParam = constructTypeCtorParameter(env, meta, rawType);
const typeParameters = typeParametersWithDefaultTypes(typeParams);
if (meta.body) {
const fnType = ts22.factory.createFunctionTypeNode(
typeParameters,
[initParam],
rawType
);
const decl = ts22.factory.createVariableDeclaration(
meta.fnName,
void 0,
fnType,
ts22.factory.createNonNullExpression(ts22.factory.createNull())
);
const declList = ts22.factory.createVariableDeclarationList([decl], ts22.NodeFlags.Const);
return ts22.factory.createVariableStatement(
void 0,
declList
);
} else {
return ts22.factory.createFunctionDeclaration(
[ts22.factory.createModifier(ts22.SyntaxKind.DeclareKeyword)],
void 0,
meta.fnName,
typeParameters,
[initParam],
rawType,
void 0
);
}
}
function generateInlineTypeCtor(env, node, meta) {
const rawTypeArgs = node.typeParameters !== void 0 ? generateGenericArgs(node.typeParameters) : void 0;
const rawType = ts22.factory.createTypeReferenceNode(node.name, rawTypeArgs);
const initParam = constructTypeCtorParameter(env, meta, rawType);
let body = void 0;
if (meta.body) {
body = ts22.factory.createBlock([
ts22.factory.createReturnStatement(ts22.factory.createNonNullExpression(ts22.factory.createNull()))
]);
}
return ts22.factory.createMethodDeclaration(
[ts22.factory.createModifier(ts22.SyntaxKind.StaticKeyword)],
void 0,
meta.fnName,
void 0,
typeParametersWithDefaultTypes(node.typeParameters),
[initParam],
rawType,
body
);
}
function constructTypeCtorParameter(env, meta, rawType) {
let initType = null;
const plainKeys = [];
const coercedKeys = [];
const signalInputKeys = [];
for (const { classPropertyName, transform, isSignal: isSignal2 } of meta.fields.inputs) {
if (isSignal2) {
signalInputKeys.push(ts22.factory.createLiteralTypeNode(ts22.factory.createStringLiteral(classPropertyName)));
} else if (!meta.coercedInputFields.has(classPropertyName)) {
plainKeys.push(ts22.factory.createLiteralTypeNode(ts22.factory.createStringLiteral(classPropertyName)));
} else {
const coercionType = transform != null ? transform.type.node : tsCreateTypeQueryForCoercedInput(rawType.typeName, classPropertyName);
coercedKeys.push(ts22.factory.createPropertySignature(
void 0,
classPropertyName,
void 0,
coercionType
));
}
}
if (plainKeys.length > 0) {
const keyTypeUnion = ts22.factory.createUnionTypeNode(plainKeys);
initType = ts22.factory.createTypeReferenceNode("Pick", [rawType, keyTypeUnion]);
}
if (coercedKeys.length > 0) {
const coercedLiteral = ts22.factory.createTypeLiteralNode(coercedKeys);
initType = initType !== null ? ts22.factory.createIntersectionTypeNode([initType, coercedLiteral]) : coercedLiteral;
}
if (signalInputKeys.length > 0) {
const keyTypeUnion = ts22.factory.createUnionTypeNode(signalInputKeys);
const unwrapDirectiveSignalInputsExpr = env.referenceExternalType(R3Identifiers2.UnwrapDirectiveSignalInputs.moduleName, R3Identifiers2.UnwrapDirectiveSignalInputs.name, [
new ExpressionType2(new WrappedNodeExpr(rawType)),
new ExpressionType2(new WrappedNodeExpr(keyTypeUnion))
]);
initType = initType !== null ? ts22.factory.createIntersectionTypeNode([initType, unwrapDirectiveSignalInputsExpr]) : unwrapDirectiveSignalInputsExpr;
}
if (initType === null) {
initType = ts22.factory.createTypeLiteralNode([]);
}
return ts22.factory.createParameterDeclaration(
void 0,
void 0,
"init",
void 0,
initType,
void 0
);
}
function generateGenericArgs(params) {
return params.map((param) => ts22.factory.createTypeReferenceNode(param.name, void 0));
}
function requiresInlineTypeCtor(node, host, env) {
return !checkIfGenericTypeBoundsCanBeEmitted(node, host, env);
}
function typeParametersWithDefaultTypes(params) {
if (params === void 0) {
return void 0;
}
return params.map((param) => {
if (param.default === void 0) {
return ts22.factory.updateTypeParameterDeclaration(param, param.modifiers, param.name, param.constraint, ts22.factory.createKeywordTypeNode(ts22.SyntaxKind.AnyKeyword));
} else {
return param;
}
});
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/environment.mjs
var Environment = class extends ReferenceEmitEnvironment {
constructor(config, importManager, refEmitter, reflector, contextFile) {
super(importManager, refEmitter, reflector, contextFile);
this.config = config;
this.nextIds = {
pipeInst: 1,
typeCtor: 1
};
this.typeCtors = /* @__PURE__ */ new Map();
this.typeCtorStatements = [];
this.pipeInsts = /* @__PURE__ */ new Map();
this.pipeInstStatements = [];
}
typeCtorFor(dir) {
const dirRef = dir.ref;
const node = dirRef.node;
if (this.typeCtors.has(node)) {
return this.typeCtors.get(node);
}
if (requiresInlineTypeCtor(node, this.reflector, this)) {
const ref = this.reference(dirRef);
const typeCtorExpr = ts23.factory.createPropertyAccessExpression(ref, "ngTypeCtor");
this.typeCtors.set(node, typeCtorExpr);
return typeCtorExpr;
} else {
const fnName = `_ctor${this.nextIds.typeCtor++}`;
const nodeTypeRef = this.referenceType(dirRef);
if (!ts23.isTypeReferenceNode(nodeTypeRef)) {
throw new Error(`Expected TypeReferenceNode from reference to ${dirRef.debugName}`);
}
const meta = {
fnName,
body: true,
fields: {
inputs: dir.inputs,
queries: dir.queries
},
coercedInputFields: dir.coercedInputFields
};
const typeParams = this.emitTypeParameters(node);
const typeCtor = generateTypeCtorDeclarationFn(this, meta, nodeTypeRef.typeName, typeParams);
this.typeCtorStatements.push(typeCtor);
const fnId = ts23.factory.createIdentifier(fnName);
this.typeCtors.set(node, fnId);
return fnId;
}
}
pipeInst(ref) {
if (this.pipeInsts.has(ref.node)) {
return this.pipeInsts.get(ref.node);
}
const pipeType = this.referenceType(ref);
const pipeInstId = ts23.factory.createIdentifier(`_pipe${this.nextIds.pipeInst++}`);
this.pipeInstStatements.push(tsDeclareVariable(pipeInstId, pipeType));
this.pipeInsts.set(ref.node, pipeInstId);
return pipeInstId;
}
reference(ref) {
const ngExpr = this.refEmitter.emit(ref, this.contextFile, ImportFlags.NoAliasing);
assertSuccessfulReferenceEmit(ngExpr, this.contextFile, "class");
return translateExpression(ngExpr.expression, this.importManager);
}
emitTypeParameters(declaration) {
const emitter = new TypeParameterEmitter(declaration.typeParameters, this.reflector);
return emitter.emit((ref) => this.referenceType(ref));
}
getPreludeStatements() {
return [
...this.pipeInstStatements,
...this.typeCtorStatements
];
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/oob.mjs
import { AbsoluteSourceSpan as AbsoluteSourceSpan3, TmplAstElement as TmplAstElement2, TmplAstForLoopBlock, TmplAstForLoopBlockEmpty } from "@angular/compiler";
import ts24 from "typescript";
var OutOfBandDiagnosticRecorderImpl = class {
constructor(resolver) {
this.resolver = resolver;
this._diagnostics = [];
this.recordedPipes = /* @__PURE__ */ new Set();
}
get diagnostics() {
return this._diagnostics;
}
missingReferenceTarget(templateId, ref) {
const mapping = this.resolver.getSourceMapping(templateId);
const value = ref.value.trim();
const errorMsg = `No directive found with exportAs '${value}'.`;
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, ref.valueSpan || ref.sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.MISSING_REFERENCE_TARGET), errorMsg));
}
missingPipe(templateId, ast) {
if (this.recordedPipes.has(ast)) {
return;
}
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `No pipe found with name '${ast.name}'.`;
const sourceSpan = this.resolver.toParseSourceSpan(templateId, ast.nameSpan);
if (sourceSpan === null) {
throw new Error(`Assertion failure: no SourceLocation found for usage of pipe '${ast.name}'.`);
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.MISSING_PIPE), errorMsg));
this.recordedPipes.add(ast);
}
deferredPipeUsedEagerly(templateId, ast) {
if (this.recordedPipes.has(ast)) {
return;
}
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `Pipe '${ast.name}' was imported via \`@Component.deferredImports\`, but was used outside of a \`@defer\` block in a template. To fix this, either use the '${ast.name}' pipe inside of a \`@defer\` block or import this dependency using the \`@Component.imports\` field.`;
const sourceSpan = this.resolver.toParseSourceSpan(templateId, ast.nameSpan);
if (sourceSpan === null) {
throw new Error(`Assertion failure: no SourceLocation found for usage of pipe '${ast.name}'.`);
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.DEFERRED_PIPE_USED_EAGERLY), errorMsg));
this.recordedPipes.add(ast);
}
deferredComponentUsedEagerly(templateId, element) {
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `Element '${element.name}' contains a component or a directive that was imported via \`@Component.deferredImports\`, but the element itself is located outside of a \`@defer\` block in a template. To fix this, either use the '${element.name}' element inside of a \`@defer\` block or import referenced component/directive dependency using the \`@Component.imports\` field.`;
const { start, end } = element.startSourceSpan;
const absoluteSourceSpan = new AbsoluteSourceSpan3(start.offset, end.offset);
const sourceSpan = this.resolver.toParseSourceSpan(templateId, absoluteSourceSpan);
if (sourceSpan === null) {
throw new Error(`Assertion failure: no SourceLocation found for usage of pipe '${element.name}'.`);
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.DEFERRED_DIRECTIVE_USED_EAGERLY), errorMsg));
}
illegalAssignmentToTemplateVar(templateId, assignment, target) {
var _a, _b;
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `Cannot use variable '${assignment.name}' as the left-hand side of an assignment expression. Template variables are read-only.`;
const sourceSpan = this.resolver.toParseSourceSpan(templateId, assignment.sourceSpan);
if (sourceSpan === null) {
throw new Error(`Assertion failure: no SourceLocation found for property binding.`);
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.WRITE_TO_READ_ONLY_VARIABLE), errorMsg, [{
text: `The variable ${assignment.name} is declared here.`,
start: ((_a = target.valueSpan) == null ? void 0 : _a.start.offset) || target.sourceSpan.start.offset,
end: ((_b = target.valueSpan) == null ? void 0 : _b.end.offset) || target.sourceSpan.end.offset,
sourceFile: mapping.node.getSourceFile()
}]));
}
duplicateTemplateVar(templateId, variable, firstDecl) {
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `Cannot redeclare variable '${variable.name}' as it was previously declared elsewhere for the same template.`;
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, variable.sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.DUPLICATE_VARIABLE_DECLARATION), errorMsg, [{
text: `The variable '${firstDecl.name}' was first declared here.`,
start: firstDecl.sourceSpan.start.offset,
end: firstDecl.sourceSpan.end.offset,
sourceFile: mapping.node.getSourceFile()
}]));
}
requiresInlineTcb(templateId, node) {
this._diagnostics.push(makeInlineDiagnostic(templateId, ErrorCode.INLINE_TCB_REQUIRED, node.name, `This component requires inline template type-checking, which is not supported by the current environment.`));
}
requiresInlineTypeConstructors(templateId, node, directives) {
let message;
if (directives.length > 1) {
message = `This component uses directives which require inline type constructors, which are not supported by the current environment.`;
} else {
message = `This component uses a directive which requires an inline type constructor, which is not supported by the current environment.`;
}
this._diagnostics.push(makeInlineDiagnostic(templateId, ErrorCode.INLINE_TYPE_CTOR_REQUIRED, node.name, message, directives.map((dir) => makeRelatedInformation(dir.name, `Requires an inline type constructor.`))));
}
suboptimalTypeInference(templateId, variables) {
const mapping = this.resolver.getSourceMapping(templateId);
let diagnosticVar = null;
for (const variable of variables) {
if (diagnosticVar === null || (variable.value === "" || variable.value === "$implicit")) {
diagnosticVar = variable;
}
}
if (diagnosticVar === null) {
return;
}
let varIdentification = `'${diagnosticVar.name}'`;
if (variables.length === 2) {
varIdentification += ` (and 1 other)`;
} else if (variables.length > 2) {
varIdentification += ` (and ${variables.length - 1} others)`;
}
const message = `This structural directive supports advanced type inference, but the current compiler configuration prevents its usage. The variable ${varIdentification} will have type 'any' as a result.
Consider enabling the 'strictTemplates' option in your tsconfig.json for better type inference within this template.`;
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, diagnosticVar.keySpan, ts24.DiagnosticCategory.Suggestion, ngErrorCode(ErrorCode.SUGGEST_SUBOPTIMAL_TYPE_INFERENCE), message));
}
splitTwoWayBinding(templateId, input, output, inputConsumer, outputConsumer) {
const mapping = this.resolver.getSourceMapping(templateId);
const errorMsg = `The property and event halves of the two-way binding '${input.name}' are not bound to the same target.
Find more at https://angular.io/guide/two-way-binding#how-two-way-binding-works`;
const relatedMessages = [];
relatedMessages.push({
text: `The property half of the binding is to the '${inputConsumer.name.text}' component.`,
start: inputConsumer.name.getStart(),
end: inputConsumer.name.getEnd(),
sourceFile: inputConsumer.name.getSourceFile()
});
if (outputConsumer instanceof TmplAstElement2) {
let message = `The event half of the binding is to a native event called '${input.name}' on the <${outputConsumer.name}> DOM element.`;
if (!mapping.node.getSourceFile().isDeclarationFile) {
message += `
Are you missing an output declaration called '${output.name}'?`;
}
relatedMessages.push({
text: message,
start: outputConsumer.sourceSpan.start.offset + 1,
end: outputConsumer.sourceSpan.start.offset + outputConsumer.name.length + 1,
sourceFile: mapping.node.getSourceFile()
});
} else {
relatedMessages.push({
text: `The event half of the binding is to the '${outputConsumer.name.text}' component.`,
start: outputConsumer.name.getStart(),
end: outputConsumer.name.getEnd(),
sourceFile: outputConsumer.name.getSourceFile()
});
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, mapping, input.keySpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.SPLIT_TWO_WAY_BINDING), errorMsg, relatedMessages));
}
missingRequiredInputs(templateId, element, directiveName, isComponent, inputAliases) {
const message = `Required input${inputAliases.length === 1 ? "" : "s"} ${inputAliases.map((n) => `'${n}'`).join(", ")} from ${isComponent ? "component" : "directive"} ${directiveName} must be specified.`;
this._diagnostics.push(makeTemplateDiagnostic(templateId, this.resolver.getSourceMapping(templateId), element.startSourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.MISSING_REQUIRED_INPUTS), message));
}
illegalForLoopTrackAccess(templateId, block, access) {
const sourceSpan = this.resolver.toParseSourceSpan(templateId, access.sourceSpan);
if (sourceSpan === null) {
throw new Error(`Assertion failure: no SourceLocation found for property read.`);
}
const message = `Cannot access '${access.name}' inside of a track expression. Only '${block.item.name}', '${block.contextVariables.$index.name}' and properties on the containing component are available to this expression.`;
this._diagnostics.push(makeTemplateDiagnostic(templateId, this.resolver.getSourceMapping(templateId), sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.ILLEGAL_FOR_LOOP_TRACK_ACCESS), message));
}
inaccessibleDeferredTriggerElement(templateId, trigger) {
let message;
if (trigger.reference === null) {
message = `Trigger cannot find reference. Make sure that the @defer block has a @placeholder with at least one root element node.`;
} else {
message = `Trigger cannot find reference "${trigger.reference}".
Check that an element with #${trigger.reference} exists in the same template and it's accessible from the @defer block.
Deferred blocks can only access triggers in same view, a parent embedded view or the root view of the @placeholder block.`;
}
this._diagnostics.push(makeTemplateDiagnostic(templateId, this.resolver.getSourceMapping(templateId), trigger.sourceSpan, ts24.DiagnosticCategory.Error, ngErrorCode(ErrorCode.INACCESSIBLE_DEFERRED_TRIGGER_ELEMENT), message));
}
controlFlowPreventingContentProjection(templateId, category, projectionNode, componentName, slotSelector, controlFlowNode, preservesWhitespaces) {
let blockName;
if (controlFlowNode instanceof TmplAstForLoopBlockEmpty) {
blockName = "@empty";
} else if (controlFlowNode instanceof TmplAstForLoopBlock) {
blockName = "@for";
} else {
blockName = "@if";
}
const lines = [
`Node matches the "${slotSelector}" slot of the "${componentName}" component, but will not be projected into the specific slot because the surrounding ${blockName} has more than one node at its root. To project the node in the right slot, you can:
`,
`1. Wrap the content of the ${blockName} block in an <ng-container/> that matches the "${slotSelector}" selector.`,
`2. Split the content of the ${blockName} block across multiple ${blockName} blocks such that each one only has a single projectable node at its root.`,
`3. Remove all content from the ${blockName} block, except for the node being projected.`
];
if (preservesWhitespaces) {
lines.push("Note: the host component has `preserveWhitespaces: true` which may cause whitespace to affect content projection.");
}
lines.push("", 'This check can be disabled using the `extendedDiagnostics.checks.controlFlowPreventingContentProjection = "suppress" compiler option.`');
this._diagnostics.push(makeTemplateDiagnostic(templateId, this.resolver.getSourceMapping(templateId), projectionNode.startSourceSpan, category, ngErrorCode(ErrorCode.CONTROL_FLOW_PREVENTING_CONTENT_PROJECTION), lines.join("\n")));
}
};
function makeInlineDiagnostic(templateId, code, node, messageText, relatedInformation) {
return {
...makeDiagnostic(code, node, messageText, relatedInformation),
componentFile: node.getSourceFile(),
templateId
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/shim.mjs
import ts25 from "typescript";
var TypeCheckShimGenerator = class {
constructor() {
this.extensionPrefix = "ngtypecheck";
this.shouldEmit = false;
}
generateShimForFile(sf, genFilePath, priorShimSf) {
if (priorShimSf !== null) {
return priorShimSf;
}
return ts25.createSourceFile(genFilePath, "export const USED_FOR_NG_TYPE_CHECKING = true;", ts25.ScriptTarget.Latest, true, ts25.ScriptKind.TS);
}
static shimFor(fileName) {
return absoluteFrom(fileName.replace(/\.tsx?$/, ".ngtypecheck.ts"));
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_check_block.mjs
import { BindingPipe, Call as Call2, createCssSelectorFromNode, CssSelector, DYNAMIC_TYPE, ImplicitReceiver as ImplicitReceiver4, PropertyRead as PropertyRead4, PropertyWrite as PropertyWrite3, R3Identifiers as R3Identifiers3, SafeCall, SafePropertyRead as SafePropertyRead3, SelectorMatcher, ThisReceiver, TmplAstBoundAttribute, TmplAstBoundText, TmplAstDeferredBlock, TmplAstElement as TmplAstElement3, TmplAstForLoopBlock as TmplAstForLoopBlock2, TmplAstIcu, TmplAstIfBlock, TmplAstIfBlockBranch, TmplAstReference as TmplAstReference3, TmplAstSwitchBlock, TmplAstTemplate as TmplAstTemplate2, TmplAstText, TmplAstTextAttribute as TmplAstTextAttribute2, TmplAstVariable as TmplAstVariable2, TransplantedType } from "@angular/compiler";
import ts28 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/diagnostics.mjs
import { AbsoluteSourceSpan as AbsoluteSourceSpan4 } from "@angular/compiler";
import ts26 from "typescript";
function wrapForDiagnostics(expr) {
return ts26.factory.createParenthesizedExpression(expr);
}
function wrapForTypeChecker(expr) {
return ts26.factory.createParenthesizedExpression(expr);
}
function addParseSpanInfo(node, span) {
let commentText;
if (span instanceof AbsoluteSourceSpan4) {
commentText = `${span.start},${span.end}`;
} else {
commentText = `${span.start.offset},${span.end.offset}`;
}
ts26.addSyntheticTrailingComment(node, ts26.SyntaxKind.MultiLineCommentTrivia, commentText, false);
}
function addTemplateId(tcb, id) {
ts26.addSyntheticLeadingComment(tcb, ts26.SyntaxKind.MultiLineCommentTrivia, id, true);
}
function shouldReportDiagnostic(diagnostic) {
const { code } = diagnostic;
if (code === 6133) {
return false;
} else if (code === 6199) {
return false;
} else if (code === 2695) {
return false;
} else if (code === 7006) {
return false;
}
return true;
}
function translateDiagnostic(diagnostic, resolver) {
if (diagnostic.file === void 0 || diagnostic.start === void 0) {
return null;
}
const fullMapping = getTemplateMapping(diagnostic.file, diagnostic.start, resolver, true);
if (fullMapping === null) {
return null;
}
const { sourceLocation, templateSourceMapping, span } = fullMapping;
return makeTemplateDiagnostic(sourceLocation.id, templateSourceMapping, span, diagnostic.category, diagnostic.code, diagnostic.messageText);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/expression.mjs
import { ASTWithSource as ASTWithSource2, Call, EmptyExpr as EmptyExpr2, PropertyRead as PropertyRead3, SafeKeyedRead, SafePropertyRead as SafePropertyRead2 } from "@angular/compiler";
import ts27 from "typescript";
var NULL_AS_ANY = ts27.factory.createAsExpression(ts27.factory.createNull(), ts27.factory.createKeywordTypeNode(ts27.SyntaxKind.AnyKeyword));
var UNDEFINED = ts27.factory.createIdentifier("undefined");
var UNARY_OPS = /* @__PURE__ */ new Map([
["+", ts27.SyntaxKind.PlusToken],
["-", ts27.SyntaxKind.MinusToken]
]);
var BINARY_OPS = /* @__PURE__ */ new Map([
["+", ts27.SyntaxKind.PlusToken],
["-", ts27.SyntaxKind.MinusToken],
["<", ts27.SyntaxKind.LessThanToken],
[">", ts27.SyntaxKind.GreaterThanToken],
["<=", ts27.SyntaxKind.LessThanEqualsToken],
[">=", ts27.SyntaxKind.GreaterThanEqualsToken],
["==", ts27.SyntaxKind.EqualsEqualsToken],
["===", ts27.SyntaxKind.EqualsEqualsEqualsToken],
["*", ts27.SyntaxKind.AsteriskToken],
["/", ts27.SyntaxKind.SlashToken],
["%", ts27.SyntaxKind.PercentToken],
["!=", ts27.SyntaxKind.ExclamationEqualsToken],
["!==", ts27.SyntaxKind.ExclamationEqualsEqualsToken],
["||", ts27.SyntaxKind.BarBarToken],
["&&", ts27.SyntaxKind.AmpersandAmpersandToken],
["&", ts27.SyntaxKind.AmpersandToken],
["|", ts27.SyntaxKind.BarToken],
["??", ts27.SyntaxKind.QuestionQuestionToken]
]);
function astToTypescript(ast, maybeResolve, config) {
const translator = new AstTranslator(maybeResolve, config);
return translator.translate(ast);
}
var AstTranslator = class {
constructor(maybeResolve, config) {
this.maybeResolve = maybeResolve;
this.config = config;
}
translate(ast) {
if (ast instanceof ASTWithSource2) {
ast = ast.ast;
}
if (ast instanceof EmptyExpr2) {
const res = ts27.factory.createIdentifier("undefined");
addParseSpanInfo(res, ast.sourceSpan);
return res;
}
const resolved = this.maybeResolve(ast);
if (resolved !== null) {
return resolved;
}
return ast.visit(this);
}
visitUnary(ast) {
const expr = this.translate(ast.expr);
const op = UNARY_OPS.get(ast.operator);
if (op === void 0) {
throw new Error(`Unsupported Unary.operator: ${ast.operator}`);
}
const node = wrapForDiagnostics(ts27.factory.createPrefixUnaryExpression(op, expr));
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitBinary(ast) {
const lhs = wrapForDiagnostics(this.translate(ast.left));
const rhs = wrapForDiagnostics(this.translate(ast.right));
const op = BINARY_OPS.get(ast.operation);
if (op === void 0) {
throw new Error(`Unsupported Binary.operation: ${ast.operation}`);
}
const node = ts27.factory.createBinaryExpression(lhs, op, rhs);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitChain(ast) {
const elements = ast.expressions.map((expr) => this.translate(expr));
const node = wrapForDiagnostics(ts27.factory.createCommaListExpression(elements));
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitConditional(ast) {
const condExpr = this.translate(ast.condition);
const trueExpr = this.translate(ast.trueExp);
const falseExpr = wrapForTypeChecker(this.translate(ast.falseExp));
const node = ts27.factory.createParenthesizedExpression(ts27.factory.createConditionalExpression(condExpr, void 0, trueExpr, void 0, falseExpr));
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitImplicitReceiver(ast) {
throw new Error("Method not implemented.");
}
visitThisReceiver(ast) {
throw new Error("Method not implemented.");
}
visitInterpolation(ast) {
return ast.expressions.reduce((lhs, ast2) => ts27.factory.createBinaryExpression(lhs, ts27.SyntaxKind.PlusToken, wrapForTypeChecker(this.translate(ast2))), ts27.factory.createStringLiteral(""));
}
visitKeyedRead(ast) {
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
const key = this.translate(ast.key);
const node = ts27.factory.createElementAccessExpression(receiver, key);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitKeyedWrite(ast) {
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
const left = ts27.factory.createElementAccessExpression(receiver, this.translate(ast.key));
const right = wrapForTypeChecker(this.translate(ast.value));
const node = wrapForDiagnostics(ts27.factory.createBinaryExpression(left, ts27.SyntaxKind.EqualsToken, right));
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitLiteralArray(ast) {
const elements = ast.expressions.map((expr) => this.translate(expr));
const literal = ts27.factory.createArrayLiteralExpression(elements);
const node = this.config.strictLiteralTypes ? literal : tsCastToAny(literal);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitLiteralMap(ast) {
const properties = ast.keys.map(({ key }, idx) => {
const value = this.translate(ast.values[idx]);
return ts27.factory.createPropertyAssignment(ts27.factory.createStringLiteral(key), value);
});
const literal = ts27.factory.createObjectLiteralExpression(properties, true);
const node = this.config.strictLiteralTypes ? literal : tsCastToAny(literal);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitLiteralPrimitive(ast) {
let node;
if (ast.value === void 0) {
node = ts27.factory.createIdentifier("undefined");
} else if (ast.value === null) {
node = ts27.factory.createNull();
} else if (typeof ast.value === "string") {
node = ts27.factory.createStringLiteral(ast.value);
} else if (typeof ast.value === "number") {
node = tsNumericExpression(ast.value);
} else if (typeof ast.value === "boolean") {
node = ast.value ? ts27.factory.createTrue() : ts27.factory.createFalse();
} else {
throw Error(`Unsupported AST value of type ${typeof ast.value}`);
}
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitNonNullAssert(ast) {
const expr = wrapForDiagnostics(this.translate(ast.expression));
const node = ts27.factory.createNonNullExpression(expr);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitPipe(ast) {
throw new Error("Method not implemented.");
}
visitPrefixNot(ast) {
const expression = wrapForDiagnostics(this.translate(ast.expression));
const node = ts27.factory.createLogicalNot(expression);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitPropertyRead(ast) {
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
const name = ts27.factory.createPropertyAccessExpression(receiver, ast.name);
addParseSpanInfo(name, ast.nameSpan);
const node = wrapForDiagnostics(name);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitPropertyWrite(ast) {
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
const left = ts27.factory.createPropertyAccessExpression(receiver, ast.name);
addParseSpanInfo(left, ast.nameSpan);
const leftWithPath = wrapForDiagnostics(left);
addParseSpanInfo(leftWithPath, ast.sourceSpan);
const right = wrapForTypeChecker(this.translate(ast.value));
const node = wrapForDiagnostics(ts27.factory.createBinaryExpression(leftWithPath, ts27.SyntaxKind.EqualsToken, right));
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitSafePropertyRead(ast) {
let node;
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
if (this.config.strictSafeNavigationTypes) {
const expr = ts27.factory.createPropertyAccessExpression(ts27.factory.createNonNullExpression(receiver), ast.name);
addParseSpanInfo(expr, ast.nameSpan);
node = ts27.factory.createParenthesizedExpression(ts27.factory.createConditionalExpression(NULL_AS_ANY, void 0, expr, void 0, UNDEFINED));
} else if (VeSafeLhsInferenceBugDetector.veWillInferAnyFor(ast)) {
node = ts27.factory.createPropertyAccessExpression(tsCastToAny(receiver), ast.name);
} else {
const expr = ts27.factory.createPropertyAccessExpression(ts27.factory.createNonNullExpression(receiver), ast.name);
addParseSpanInfo(expr, ast.nameSpan);
node = tsCastToAny(expr);
}
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitSafeKeyedRead(ast) {
const receiver = wrapForDiagnostics(this.translate(ast.receiver));
const key = this.translate(ast.key);
let node;
if (this.config.strictSafeNavigationTypes) {
const expr = ts27.factory.createElementAccessExpression(ts27.factory.createNonNullExpression(receiver), key);
addParseSpanInfo(expr, ast.sourceSpan);
node = ts27.factory.createParenthesizedExpression(ts27.factory.createConditionalExpression(NULL_AS_ANY, void 0, expr, void 0, UNDEFINED));
} else if (VeSafeLhsInferenceBugDetector.veWillInferAnyFor(ast)) {
node = ts27.factory.createElementAccessExpression(tsCastToAny(receiver), key);
} else {
const expr = ts27.factory.createElementAccessExpression(ts27.factory.createNonNullExpression(receiver), key);
addParseSpanInfo(expr, ast.sourceSpan);
node = tsCastToAny(expr);
}
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitCall(ast) {
const args = ast.args.map((expr2) => this.translate(expr2));
let expr;
const receiver = ast.receiver;
if (receiver instanceof PropertyRead3) {
const resolved = this.maybeResolve(receiver);
if (resolved !== null) {
expr = resolved;
} else {
const propertyReceiver = wrapForDiagnostics(this.translate(receiver.receiver));
expr = ts27.factory.createPropertyAccessExpression(propertyReceiver, receiver.name);
addParseSpanInfo(expr, receiver.nameSpan);
}
} else {
expr = this.translate(receiver);
}
let node;
if (ast.receiver instanceof SafePropertyRead2 || ast.receiver instanceof SafeKeyedRead) {
node = this.convertToSafeCall(ast, expr, args);
} else {
node = ts27.factory.createCallExpression(expr, void 0, args);
}
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
visitSafeCall(ast) {
const args = ast.args.map((expr2) => this.translate(expr2));
const expr = wrapForDiagnostics(this.translate(ast.receiver));
const node = this.convertToSafeCall(ast, expr, args);
addParseSpanInfo(node, ast.sourceSpan);
return node;
}
convertToSafeCall(ast, expr, args) {
if (this.config.strictSafeNavigationTypes) {
const call = ts27.factory.createCallExpression(ts27.factory.createNonNullExpression(expr), void 0, args);
return ts27.factory.createParenthesizedExpression(ts27.factory.createConditionalExpression(NULL_AS_ANY, void 0, call, void 0, UNDEFINED));
}
if (VeSafeLhsInferenceBugDetector.veWillInferAnyFor(ast)) {
return ts27.factory.createCallExpression(tsCastToAny(expr), void 0, args);
}
return tsCastToAny(ts27.factory.createCallExpression(ts27.factory.createNonNullExpression(expr), void 0, args));
}
};
var _VeSafeLhsInferenceBugDetector = class {
static veWillInferAnyFor(ast) {
const visitor = _VeSafeLhsInferenceBugDetector.SINGLETON;
return ast instanceof Call ? ast.visit(visitor) : ast.receiver.visit(visitor);
}
visitUnary(ast) {
return ast.expr.visit(this);
}
visitBinary(ast) {
return ast.left.visit(this) || ast.right.visit(this);
}
visitChain(ast) {
return false;
}
visitConditional(ast) {
return ast.condition.visit(this) || ast.trueExp.visit(this) || ast.falseExp.visit(this);
}
visitCall(ast) {
return true;
}
visitSafeCall(ast) {
return false;
}
visitImplicitReceiver(ast) {
return false;
}
visitThisReceiver(ast) {
return false;
}
visitInterpolation(ast) {
return ast.expressions.some((exp) => exp.visit(this));
}
visitKeyedRead(ast) {
return false;
}
visitKeyedWrite(ast) {
return false;
}
visitLiteralArray(ast) {
return true;
}
visitLiteralMap(ast) {
return true;
}
visitLiteralPrimitive(ast) {
return false;
}
visitPipe(ast) {
return true;
}
visitPrefixNot(ast) {
return ast.expression.visit(this);
}
visitNonNullAssert(ast) {
return ast.expression.visit(this);
}
visitPropertyRead(ast) {
return false;
}
visitPropertyWrite(ast) {
return false;
}
visitSafePropertyRead(ast) {
return false;
}
visitSafeKeyedRead(ast) {
return false;
}
};
var VeSafeLhsInferenceBugDetector = _VeSafeLhsInferenceBugDetector;
(() => {
_VeSafeLhsInferenceBugDetector.SINGLETON = new _VeSafeLhsInferenceBugDetector();
})();
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/template_semantics.mjs
import { ImplicitReceiver as ImplicitReceiver3, RecursiveAstVisitor as RecursiveAstVisitor2, TmplAstVariable } from "@angular/compiler";
var ExpressionSemanticVisitor = class extends RecursiveAstVisitor2 {
constructor(templateId, boundTarget, oob) {
super();
this.templateId = templateId;
this.boundTarget = boundTarget;
this.oob = oob;
}
visitPropertyWrite(ast, context) {
super.visitPropertyWrite(ast, context);
if (!(ast.receiver instanceof ImplicitReceiver3)) {
return;
}
const target = this.boundTarget.getExpressionTarget(ast);
if (target instanceof TmplAstVariable) {
this.oob.illegalAssignmentToTemplateVar(this.templateId, ast, target);
}
}
static visit(ast, id, boundTarget, oob) {
ast.visit(new ExpressionSemanticVisitor(id, boundTarget, oob));
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_check_block.mjs
var TcbGenericContextBehavior;
(function(TcbGenericContextBehavior2) {
TcbGenericContextBehavior2[TcbGenericContextBehavior2["UseEmitter"] = 0] = "UseEmitter";
TcbGenericContextBehavior2[TcbGenericContextBehavior2["CopyClassNodes"] = 1] = "CopyClassNodes";
TcbGenericContextBehavior2[TcbGenericContextBehavior2["FallbackToAny"] = 2] = "FallbackToAny";
})(TcbGenericContextBehavior || (TcbGenericContextBehavior = {}));
function generateTypeCheckBlock(env, ref, name, meta, domSchemaChecker, oobRecorder, genericContextBehavior) {
const tcb = new Context(env, domSchemaChecker, oobRecorder, meta.id, meta.boundTarget, meta.pipes, meta.schemas, meta.isStandalone, meta.preserveWhitespaces);
const scope = Scope.forNodes(tcb, null, null, tcb.boundTarget.target.template, null);
const ctxRawType = env.referenceType(ref);
if (!ts28.isTypeReferenceNode(ctxRawType)) {
throw new Error(`Expected TypeReferenceNode when referencing the ctx param for ${ref.debugName}`);
}
let typeParameters = void 0;
let typeArguments = void 0;
if (ref.node.typeParameters !== void 0) {
if (!env.config.useContextGenericType) {
genericContextBehavior = TcbGenericContextBehavior.FallbackToAny;
}
switch (genericContextBehavior) {
case TcbGenericContextBehavior.UseEmitter:
typeParameters = new TypeParameterEmitter(ref.node.typeParameters, env.reflector).emit((typeRef) => env.referenceType(typeRef));
typeArguments = typeParameters.map((param) => ts28.factory.createTypeReferenceNode(param.name));
break;
case TcbGenericContextBehavior.CopyClassNodes:
typeParameters = [...ref.node.typeParameters];
typeArguments = typeParameters.map((param) => ts28.factory.createTypeReferenceNode(param.name));
break;
case TcbGenericContextBehavior.FallbackToAny:
typeArguments = ref.node.typeParameters.map(() => ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
break;
}
}
const paramList = [tcbThisParam(ctxRawType.typeName, typeArguments)];
const scopeStatements = scope.render();
const innerBody = ts28.factory.createBlock([
...env.getPreludeStatements(),
...scopeStatements
]);
const body = ts28.factory.createBlock([ts28.factory.createIfStatement(ts28.factory.createTrue(), innerBody, void 0)]);
const fnDecl = ts28.factory.createFunctionDeclaration(
void 0,
void 0,
name,
env.config.useContextGenericType ? typeParameters : void 0,
paramList,
void 0,
body
);
addTemplateId(fnDecl, meta.id);
return fnDecl;
}
var TcbOp = class {
circularFallback() {
return INFER_TYPE_FOR_CIRCULAR_OP_EXPR;
}
};
var TcbElementOp = class extends TcbOp {
constructor(tcb, scope, element) {
super();
this.tcb = tcb;
this.scope = scope;
this.element = element;
}
get optional() {
return true;
}
execute() {
const id = this.tcb.allocateId();
const initializer = tsCreateElement(this.element.name);
addParseSpanInfo(initializer, this.element.startSourceSpan || this.element.sourceSpan);
this.scope.addStatement(tsCreateVariable(id, initializer));
return id;
}
};
var TcbTemplateVariableOp = class extends TcbOp {
constructor(tcb, scope, template, variable) {
super();
this.tcb = tcb;
this.scope = scope;
this.template = template;
this.variable = variable;
}
get optional() {
return false;
}
execute() {
const ctx = this.scope.resolve(this.template);
const id = this.tcb.allocateId();
const initializer = ts28.factory.createPropertyAccessExpression(
ctx,
this.variable.value || "$implicit"
);
addParseSpanInfo(id, this.variable.keySpan);
let variable;
if (this.variable.valueSpan !== void 0) {
addParseSpanInfo(initializer, this.variable.valueSpan);
variable = tsCreateVariable(id, wrapForTypeChecker(initializer));
} else {
variable = tsCreateVariable(id, initializer);
}
addParseSpanInfo(variable.declarationList.declarations[0], this.variable.sourceSpan);
this.scope.addStatement(variable);
return id;
}
};
var TcbTemplateContextOp = class extends TcbOp {
constructor(tcb, scope) {
super();
this.tcb = tcb;
this.scope = scope;
this.optional = true;
}
execute() {
const ctx = this.tcb.allocateId();
const type = ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword);
this.scope.addStatement(tsDeclareVariable(ctx, type));
return ctx;
}
};
var TcbTemplateBodyOp = class extends TcbOp {
constructor(tcb, scope, template) {
super();
this.tcb = tcb;
this.scope = scope;
this.template = template;
}
get optional() {
return false;
}
execute() {
const directiveGuards = [];
const directives = this.tcb.boundTarget.getDirectivesOfNode(this.template);
if (directives !== null) {
for (const dir of directives) {
const dirInstId = this.scope.resolve(this.template, dir);
const dirId = this.tcb.env.reference(dir.ref);
dir.ngTemplateGuards.forEach((guard2) => {
const boundInput = this.template.inputs.find((i) => i.name === guard2.inputName) || this.template.templateAttrs.find((i) => i instanceof TmplAstBoundAttribute && i.name === guard2.inputName);
if (boundInput !== void 0) {
const expr = tcbExpression(boundInput.value, this.tcb, this.scope);
markIgnoreDiagnostics(expr);
if (guard2.type === "binding") {
directiveGuards.push(expr);
} else {
const guardInvoke = tsCallMethod(dirId, `ngTemplateGuard_${guard2.inputName}`, [
dirInstId,
expr
]);
addParseSpanInfo(guardInvoke, boundInput.value.sourceSpan);
directiveGuards.push(guardInvoke);
}
}
});
if (dir.hasNgTemplateContextGuard) {
if (this.tcb.env.config.applyTemplateContextGuards) {
const ctx = this.scope.resolve(this.template);
const guardInvoke = tsCallMethod(dirId, "ngTemplateContextGuard", [dirInstId, ctx]);
addParseSpanInfo(guardInvoke, this.template.sourceSpan);
directiveGuards.push(guardInvoke);
} else if (this.template.variables.length > 0 && this.tcb.env.config.suggestionsForSuboptimalTypeInference) {
this.tcb.oobRecorder.suboptimalTypeInference(this.tcb.id, this.template.variables);
}
}
}
}
let guard = null;
if (directiveGuards.length > 0) {
guard = directiveGuards.reduce((expr, dirGuard) => ts28.factory.createBinaryExpression(expr, ts28.SyntaxKind.AmpersandAmpersandToken, dirGuard), directiveGuards.pop());
}
const tmplScope = Scope.forNodes(this.tcb, this.scope, this.template, this.template.children, guard);
const statements = tmplScope.render();
if (statements.length === 0) {
return null;
}
let tmplBlock = ts28.factory.createBlock(statements);
if (guard !== null) {
tmplBlock = ts28.factory.createIfStatement(guard, tmplBlock);
}
this.scope.addStatement(tmplBlock);
return null;
}
};
var TcbExpressionOp = class extends TcbOp {
constructor(tcb, scope, expression) {
super();
this.tcb = tcb;
this.scope = scope;
this.expression = expression;
}
get optional() {
return false;
}
execute() {
const expr = tcbExpression(this.expression, this.tcb, this.scope);
this.scope.addStatement(ts28.factory.createExpressionStatement(expr));
return null;
}
};
var TcbDirectiveTypeOpBase = class extends TcbOp {
constructor(tcb, scope, node, dir) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.dir = dir;
}
get optional() {
return true;
}
execute() {
const dirRef = this.dir.ref;
const rawType = this.tcb.env.referenceType(this.dir.ref);
let type;
if (this.dir.isGeneric === false || dirRef.node.typeParameters === void 0) {
type = rawType;
} else {
if (!ts28.isTypeReferenceNode(rawType)) {
throw new Error(`Expected TypeReferenceNode when referencing the type for ${this.dir.ref.debugName}`);
}
const typeArguments = dirRef.node.typeParameters.map(() => ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
type = ts28.factory.createTypeReferenceNode(rawType.typeName, typeArguments);
}
const id = this.tcb.allocateId();
addExpressionIdentifier(id, ExpressionIdentifier.DIRECTIVE);
addParseSpanInfo(id, this.node.startSourceSpan || this.node.sourceSpan);
this.scope.addStatement(tsDeclareVariable(id, type));
return id;
}
};
var TcbNonGenericDirectiveTypeOp = class extends TcbDirectiveTypeOpBase {
execute() {
const dirRef = this.dir.ref;
if (this.dir.isGeneric) {
throw new Error(`Assertion Error: expected ${dirRef.debugName} not to be generic.`);
}
return super.execute();
}
};
var TcbGenericDirectiveTypeWithAnyParamsOp = class extends TcbDirectiveTypeOpBase {
execute() {
const dirRef = this.dir.ref;
if (dirRef.node.typeParameters === void 0) {
throw new Error(`Assertion Error: expected typeParameters when creating a declaration for ${dirRef.debugName}`);
}
return super.execute();
}
};
var TcbReferenceOp = class extends TcbOp {
constructor(tcb, scope, node, host, target) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.host = host;
this.target = target;
this.optional = true;
}
execute() {
const id = this.tcb.allocateId();
let initializer = this.target instanceof TmplAstTemplate2 || this.target instanceof TmplAstElement3 ? this.scope.resolve(this.target) : this.scope.resolve(this.host, this.target);
if (this.target instanceof TmplAstElement3 && !this.tcb.env.config.checkTypeOfDomReferences || !this.tcb.env.config.checkTypeOfNonDomReferences) {
initializer = ts28.factory.createAsExpression(initializer, ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
} else if (this.target instanceof TmplAstTemplate2) {
initializer = ts28.factory.createAsExpression(initializer, ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
initializer = ts28.factory.createAsExpression(initializer, this.tcb.env.referenceExternalType("@angular/core", "TemplateRef", [DYNAMIC_TYPE]));
initializer = ts28.factory.createParenthesizedExpression(initializer);
}
addParseSpanInfo(initializer, this.node.sourceSpan);
addParseSpanInfo(id, this.node.keySpan);
this.scope.addStatement(tsCreateVariable(id, initializer));
return id;
}
};
var TcbInvalidReferenceOp = class extends TcbOp {
constructor(tcb, scope) {
super();
this.tcb = tcb;
this.scope = scope;
this.optional = true;
}
execute() {
const id = this.tcb.allocateId();
this.scope.addStatement(tsCreateVariable(id, NULL_AS_ANY));
return id;
}
};
var TcbDirectiveCtorOp = class extends TcbOp {
constructor(tcb, scope, node, dir) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.dir = dir;
}
get optional() {
return true;
}
execute() {
const id = this.tcb.allocateId();
addExpressionIdentifier(id, ExpressionIdentifier.DIRECTIVE);
addParseSpanInfo(id, this.node.startSourceSpan || this.node.sourceSpan);
const genericInputs = /* @__PURE__ */ new Map();
const boundAttrs = getBoundAttributes(this.dir, this.node);
for (const attr of boundAttrs) {
if (!this.tcb.env.config.checkTypeOfAttributes && attr.attribute instanceof TmplAstTextAttribute2) {
continue;
}
for (const { fieldName } of attr.inputs) {
if (genericInputs.has(fieldName)) {
continue;
}
const expression = translateInput(attr.attribute, this.tcb, this.scope);
genericInputs.set(fieldName, {
type: "binding",
field: fieldName,
expression,
sourceSpan: attr.attribute.sourceSpan
});
}
}
for (const { classPropertyName } of this.dir.inputs) {
if (!genericInputs.has(classPropertyName)) {
genericInputs.set(classPropertyName, { type: "unset", field: classPropertyName });
}
}
const typeCtor = tcbCallTypeCtor(this.dir, this.tcb, Array.from(genericInputs.values()));
markIgnoreDiagnostics(typeCtor);
this.scope.addStatement(tsCreateVariable(id, typeCtor));
return id;
}
circularFallback() {
return new TcbDirectiveCtorCircularFallbackOp(this.tcb, this.scope, this.node, this.dir);
}
};
var TcbDirectiveInputsOp = class extends TcbOp {
constructor(tcb, scope, node, dir) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.dir = dir;
}
get optional() {
return false;
}
execute() {
let dirId = null;
const boundAttrs = getBoundAttributes(this.dir, this.node);
const seenRequiredInputs = /* @__PURE__ */ new Set();
for (const attr of boundAttrs) {
const expr = widenBinding(translateInput(attr.attribute, this.tcb, this.scope), this.tcb);
let assignment = wrapForDiagnostics(expr);
for (const { fieldName, required, transformType, isSignal: isSignal2 } of attr.inputs) {
let target;
if (required) {
seenRequiredInputs.add(fieldName);
}
if (this.dir.coercedInputFields.has(fieldName)) {
let type;
if (transformType !== null) {
type = this.tcb.env.referenceTransplantedType(new TransplantedType(transformType));
} else {
const dirTypeRef = this.tcb.env.referenceType(this.dir.ref);
if (!ts28.isTypeReferenceNode(dirTypeRef)) {
throw new Error(`Expected TypeReferenceNode from reference to ${this.dir.ref.debugName}`);
}
type = tsCreateTypeQueryForCoercedInput(dirTypeRef.typeName, fieldName);
}
const id = this.tcb.allocateId();
this.scope.addStatement(tsDeclareVariable(id, type));
target = id;
} else if (this.dir.undeclaredInputFields.has(fieldName)) {
continue;
} else if (!this.tcb.env.config.honorAccessModifiersForInputBindings && this.dir.restrictedInputFields.has(fieldName)) {
if (dirId === null) {
dirId = this.scope.resolve(this.node, this.dir);
}
const id = this.tcb.allocateId();
const dirTypeRef = this.tcb.env.referenceType(this.dir.ref);
if (!ts28.isTypeReferenceNode(dirTypeRef)) {
throw new Error(`Expected TypeReferenceNode from reference to ${this.dir.ref.debugName}`);
}
const type = ts28.factory.createIndexedAccessTypeNode(ts28.factory.createTypeQueryNode(dirId), ts28.factory.createLiteralTypeNode(ts28.factory.createStringLiteral(fieldName)));
const temp = tsDeclareVariable(id, type);
this.scope.addStatement(temp);
target = id;
} else {
if (dirId === null) {
dirId = this.scope.resolve(this.node, this.dir);
}
target = this.dir.stringLiteralInputFields.has(fieldName) ? ts28.factory.createElementAccessExpression(dirId, ts28.factory.createStringLiteral(fieldName)) : ts28.factory.createPropertyAccessExpression(dirId, ts28.factory.createIdentifier(fieldName));
}
if (isSignal2) {
const inputSignalBrandWriteSymbol = this.tcb.env.referenceExternalSymbol(R3Identifiers3.InputSignalBrandWriteType.moduleName, R3Identifiers3.InputSignalBrandWriteType.name);
if (!ts28.isIdentifier(inputSignalBrandWriteSymbol) && !ts28.isPropertyAccessExpression(inputSignalBrandWriteSymbol)) {
throw new Error(`Expected identifier or property access for reference to ${R3Identifiers3.InputSignalBrandWriteType.name}`);
}
target = ts28.factory.createElementAccessExpression(target, inputSignalBrandWriteSymbol);
}
if (attr.attribute.keySpan !== void 0) {
addParseSpanInfo(target, attr.attribute.keySpan);
}
assignment = ts28.factory.createBinaryExpression(target, ts28.SyntaxKind.EqualsToken, assignment);
}
addParseSpanInfo(assignment, attr.attribute.sourceSpan);
if (!this.tcb.env.config.checkTypeOfAttributes && attr.attribute instanceof TmplAstTextAttribute2) {
markIgnoreDiagnostics(assignment);
}
this.scope.addStatement(ts28.factory.createExpressionStatement(assignment));
}
this.checkRequiredInputs(seenRequiredInputs);
return null;
}
checkRequiredInputs(seenRequiredInputs) {
const missing = [];
for (const input of this.dir.inputs) {
if (input.required && !seenRequiredInputs.has(input.classPropertyName)) {
missing.push(input.bindingPropertyName);
}
}
if (missing.length > 0) {
this.tcb.oobRecorder.missingRequiredInputs(this.tcb.id, this.node, this.dir.name, this.dir.isComponent, missing);
}
}
};
var TcbDirectiveCtorCircularFallbackOp = class extends TcbOp {
constructor(tcb, scope, node, dir) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.dir = dir;
}
get optional() {
return false;
}
execute() {
const id = this.tcb.allocateId();
const typeCtor = this.tcb.env.typeCtorFor(this.dir);
const circularPlaceholder = ts28.factory.createCallExpression(typeCtor, void 0, [ts28.factory.createNonNullExpression(ts28.factory.createNull())]);
this.scope.addStatement(tsCreateVariable(id, circularPlaceholder));
return id;
}
};
var TcbDomSchemaCheckerOp = class extends TcbOp {
constructor(tcb, element, checkElement, claimedInputs) {
super();
this.tcb = tcb;
this.element = element;
this.checkElement = checkElement;
this.claimedInputs = claimedInputs;
}
get optional() {
return false;
}
execute() {
var _a;
if (this.checkElement) {
this.tcb.domSchemaChecker.checkElement(this.tcb.id, this.element, this.tcb.schemas, this.tcb.hostIsStandalone);
}
for (const binding of this.element.inputs) {
const isPropertyBinding = binding.type === 0 || binding.type === 5;
if (isPropertyBinding && this.claimedInputs.has(binding.name)) {
continue;
}
if (isPropertyBinding && binding.name !== "style" && binding.name !== "class") {
const propertyName = (_a = ATTR_TO_PROP.get(binding.name)) != null ? _a : binding.name;
this.tcb.domSchemaChecker.checkProperty(this.tcb.id, this.element, propertyName, binding.sourceSpan, this.tcb.schemas, this.tcb.hostIsStandalone);
}
}
return null;
}
};
var TcbControlFlowContentProjectionOp = class extends TcbOp {
constructor(tcb, element, ngContentSelectors, componentName) {
super();
this.tcb = tcb;
this.element = element;
this.ngContentSelectors = ngContentSelectors;
this.componentName = componentName;
this.optional = false;
this.category = tcb.env.config.controlFlowPreventingContentProjection === "error" ? ts28.DiagnosticCategory.Error : ts28.DiagnosticCategory.Warning;
}
execute() {
const controlFlowToCheck = this.findPotentialControlFlowNodes();
if (controlFlowToCheck.length > 0) {
const matcher = new SelectorMatcher();
for (const selector of this.ngContentSelectors) {
if (selector !== "*") {
matcher.addSelectables(CssSelector.parse(selector), selector);
}
}
for (const root of controlFlowToCheck) {
for (const child of root.children) {
if (child instanceof TmplAstElement3 || child instanceof TmplAstTemplate2) {
matcher.match(createCssSelectorFromNode(child), (_, originalSelector) => {
this.tcb.oobRecorder.controlFlowPreventingContentProjection(this.tcb.id, this.category, child, this.componentName, originalSelector, root, this.tcb.hostPreserveWhitespaces);
});
}
}
}
}
return null;
}
findPotentialControlFlowNodes() {
const result = [];
for (const child of this.element.children) {
let eligibleNode = null;
if (child instanceof TmplAstForLoopBlock2) {
if (this.shouldCheck(child)) {
result.push(child);
}
if (child.empty !== null && this.shouldCheck(child.empty)) {
result.push(child.empty);
}
} else if (child instanceof TmplAstIfBlock) {
eligibleNode = child.branches[0];
}
if (eligibleNode === null || eligibleNode.children.length < 2) {
continue;
}
const rootNodeCount = eligibleNode.children.reduce((count, node) => {
if (!(node instanceof TmplAstText) || this.tcb.hostPreserveWhitespaces || node.value.trim().length > 0) {
count++;
}
return count;
}, 0);
if (rootNodeCount > 1) {
result.push(eligibleNode);
}
}
return result;
}
shouldCheck(node) {
if (node.children.length < 2) {
return false;
}
const rootNodeCount = node.children.reduce((count, node2) => {
if (!(node2 instanceof TmplAstText) || this.tcb.hostPreserveWhitespaces || node2.value.trim().length > 0) {
count++;
}
return count;
}, 0);
return rootNodeCount > 1;
}
};
var ATTR_TO_PROP = new Map(Object.entries({
"class": "className",
"for": "htmlFor",
"formaction": "formAction",
"innerHtml": "innerHTML",
"readonly": "readOnly",
"tabindex": "tabIndex"
}));
var TcbUnclaimedInputsOp = class extends TcbOp {
constructor(tcb, scope, element, claimedInputs) {
super();
this.tcb = tcb;
this.scope = scope;
this.element = element;
this.claimedInputs = claimedInputs;
}
get optional() {
return false;
}
execute() {
var _a;
let elId = null;
for (const binding of this.element.inputs) {
const isPropertyBinding = binding.type === 0 || binding.type === 5;
if (isPropertyBinding && this.claimedInputs.has(binding.name)) {
continue;
}
const expr = widenBinding(tcbExpression(binding.value, this.tcb, this.scope), this.tcb);
if (this.tcb.env.config.checkTypeOfDomBindings && isPropertyBinding) {
if (binding.name !== "style" && binding.name !== "class") {
if (elId === null) {
elId = this.scope.resolve(this.element);
}
const propertyName = (_a = ATTR_TO_PROP.get(binding.name)) != null ? _a : binding.name;
const prop = ts28.factory.createElementAccessExpression(elId, ts28.factory.createStringLiteral(propertyName));
const stmt = ts28.factory.createBinaryExpression(prop, ts28.SyntaxKind.EqualsToken, wrapForDiagnostics(expr));
addParseSpanInfo(stmt, binding.sourceSpan);
this.scope.addStatement(ts28.factory.createExpressionStatement(stmt));
} else {
this.scope.addStatement(ts28.factory.createExpressionStatement(expr));
}
} else {
this.scope.addStatement(ts28.factory.createExpressionStatement(expr));
}
}
return null;
}
};
var TcbDirectiveOutputsOp = class extends TcbOp {
constructor(tcb, scope, node, dir) {
super();
this.tcb = tcb;
this.scope = scope;
this.node = node;
this.dir = dir;
}
get optional() {
return false;
}
execute() {
let dirId = null;
const outputs = this.dir.outputs;
for (const output of this.node.outputs) {
if (output.type === 1 || !outputs.hasBindingPropertyName(output.name)) {
continue;
}
if (this.tcb.env.config.checkTypeOfOutputEvents && output.name.endsWith("Change")) {
const inputName = output.name.slice(0, -6);
isSplitTwoWayBinding(inputName, output, this.node.inputs, this.tcb);
}
const field = outputs.getByBindingPropertyName(output.name)[0].classPropertyName;
if (dirId === null) {
dirId = this.scope.resolve(this.node, this.dir);
}
const outputField = ts28.factory.createElementAccessExpression(dirId, ts28.factory.createStringLiteral(field));
addParseSpanInfo(outputField, output.keySpan);
if (this.tcb.env.config.checkTypeOfOutputEvents) {
const handler = tcbCreateEventHandler(output, this.tcb, this.scope, 0);
const subscribeFn = ts28.factory.createPropertyAccessExpression(outputField, "subscribe");
const call = ts28.factory.createCallExpression(subscribeFn, void 0, [handler]);
addParseSpanInfo(call, output.sourceSpan);
this.scope.addStatement(ts28.factory.createExpressionStatement(call));
} else {
this.scope.addStatement(ts28.factory.createExpressionStatement(outputField));
const handler = tcbCreateEventHandler(output, this.tcb, this.scope, 1);
this.scope.addStatement(ts28.factory.createExpressionStatement(handler));
}
ExpressionSemanticVisitor.visit(output.handler, this.tcb.id, this.tcb.boundTarget, this.tcb.oobRecorder);
}
return null;
}
};
var TcbUnclaimedOutputsOp = class extends TcbOp {
constructor(tcb, scope, element, claimedOutputs) {
super();
this.tcb = tcb;
this.scope = scope;
this.element = element;
this.claimedOutputs = claimedOutputs;
}
get optional() {
return false;
}
execute() {
let elId = null;
for (const output of this.element.outputs) {
if (this.claimedOutputs.has(output.name)) {
continue;
}
if (this.tcb.env.config.checkTypeOfOutputEvents && output.name.endsWith("Change")) {
const inputName = output.name.slice(0, -6);
if (isSplitTwoWayBinding(inputName, output, this.element.inputs, this.tcb)) {
continue;
}
}
if (output.type === 1) {
const eventType = this.tcb.env.config.checkTypeOfAnimationEvents ? this.tcb.env.referenceExternalType("@angular/animations", "AnimationEvent") : 1;
const handler = tcbCreateEventHandler(output, this.tcb, this.scope, eventType);
this.scope.addStatement(ts28.factory.createExpressionStatement(handler));
} else if (this.tcb.env.config.checkTypeOfDomEvents) {
const handler = tcbCreateEventHandler(output, this.tcb, this.scope, 0);
if (elId === null) {
elId = this.scope.resolve(this.element);
}
const propertyAccess = ts28.factory.createPropertyAccessExpression(elId, "addEventListener");
addParseSpanInfo(propertyAccess, output.keySpan);
const call = ts28.factory.createCallExpression(
propertyAccess,
void 0,
[ts28.factory.createStringLiteral(output.name), handler]
);
addParseSpanInfo(call, output.sourceSpan);
this.scope.addStatement(ts28.factory.createExpressionStatement(call));
} else {
const handler = tcbCreateEventHandler(output, this.tcb, this.scope, 1);
this.scope.addStatement(ts28.factory.createExpressionStatement(handler));
}
ExpressionSemanticVisitor.visit(output.handler, this.tcb.id, this.tcb.boundTarget, this.tcb.oobRecorder);
}
return null;
}
};
var TcbComponentContextCompletionOp = class extends TcbOp {
constructor(scope) {
super();
this.scope = scope;
this.optional = false;
}
execute() {
const ctx = ts28.factory.createThis();
const ctxDot = ts28.factory.createPropertyAccessExpression(ctx, "");
markIgnoreDiagnostics(ctxDot);
addExpressionIdentifier(ctxDot, ExpressionIdentifier.COMPONENT_COMPLETION);
this.scope.addStatement(ts28.factory.createExpressionStatement(ctxDot));
return null;
}
};
var TcbBlockVariableOp = class extends TcbOp {
constructor(tcb, scope, initializer, variable) {
super();
this.tcb = tcb;
this.scope = scope;
this.initializer = initializer;
this.variable = variable;
}
get optional() {
return false;
}
execute() {
const id = this.tcb.allocateId();
addParseSpanInfo(id, this.variable.keySpan);
const variable = tsCreateVariable(id, wrapForTypeChecker(this.initializer));
addParseSpanInfo(variable.declarationList.declarations[0], this.variable.sourceSpan);
this.scope.addStatement(variable);
return id;
}
};
var TcbBlockImplicitVariableOp = class extends TcbOp {
constructor(tcb, scope, type, variable) {
super();
this.tcb = tcb;
this.scope = scope;
this.type = type;
this.variable = variable;
this.optional = true;
}
execute() {
const id = this.tcb.allocateId();
addParseSpanInfo(id, this.variable.keySpan);
const variable = tsDeclareVariable(id, this.type);
addParseSpanInfo(variable.declarationList.declarations[0], this.variable.sourceSpan);
this.scope.addStatement(variable);
return id;
}
};
var TcbIfOp = class extends TcbOp {
constructor(tcb, scope, block) {
super();
this.tcb = tcb;
this.scope = scope;
this.block = block;
this.expressionScopes = /* @__PURE__ */ new Map();
}
get optional() {
return false;
}
execute() {
const root = this.generateBranch(0);
root && this.scope.addStatement(root);
return null;
}
generateBranch(index) {
const branch = this.block.branches[index];
if (!branch) {
return void 0;
}
if (branch.expression === null) {
const branchScope = Scope.forNodes(this.tcb, this.scope, null, branch.children, this.generateBranchGuard(index));
return ts28.factory.createBlock(branchScope.render());
}
const expressionScope = Scope.forNodes(this.tcb, this.scope, branch, [], null);
expressionScope.render().forEach((stmt) => this.scope.addStatement(stmt));
this.expressionScopes.set(branch, expressionScope);
const expression = branch.expressionAlias === null ? tcbExpression(branch.expression, this.tcb, expressionScope) : expressionScope.resolve(branch.expressionAlias);
const bodyScope = Scope.forNodes(this.tcb, expressionScope, null, branch.children, this.generateBranchGuard(index));
return ts28.factory.createIfStatement(expression, ts28.factory.createBlock(bodyScope.render()), this.generateBranch(index + 1));
}
generateBranchGuard(index) {
let guard = null;
for (let i = 0; i <= index; i++) {
const branch = this.block.branches[i];
if (branch.expression === null) {
continue;
}
if (!this.expressionScopes.has(branch)) {
throw new Error(`Could not determine expression scope of branch at index ${i}`);
}
const expressionScope = this.expressionScopes.get(branch);
let expression;
if (branch.expressionAlias === null) {
expression = tcbExpression(branch.expression, this.tcb, expressionScope);
markIgnoreDiagnostics(expression);
} else {
expression = expressionScope.resolve(branch.expressionAlias);
}
const comparisonExpression = i === index ? expression : ts28.factory.createPrefixUnaryExpression(ts28.SyntaxKind.ExclamationToken, ts28.factory.createParenthesizedExpression(expression));
guard = guard === null ? comparisonExpression : ts28.factory.createBinaryExpression(guard, ts28.SyntaxKind.AmpersandAmpersandToken, comparisonExpression);
}
return guard;
}
};
var TcbSwitchOp = class extends TcbOp {
constructor(tcb, scope, block) {
super();
this.tcb = tcb;
this.scope = scope;
this.block = block;
}
get optional() {
return false;
}
execute() {
const comparisonExpression = tcbExpression(this.block.expression, this.tcb, this.scope);
markIgnoreDiagnostics(comparisonExpression);
const expression = ts28.factory.createParenthesizedExpression(comparisonExpression);
const root = this.generateCase(0, expression, null);
if (root !== void 0) {
this.scope.addStatement(root);
}
return null;
}
generateCase(index, switchValue, defaultCase) {
if (index >= this.block.cases.length) {
if (defaultCase !== null) {
const defaultScope = Scope.forNodes(this.tcb, this.scope, null, defaultCase.children, this.generateGuard(defaultCase, switchValue));
return ts28.factory.createBlock(defaultScope.render());
}
return void 0;
}
const current = this.block.cases[index];
if (current.expression === null) {
return this.generateCase(index + 1, switchValue, current);
}
const caseScope = Scope.forNodes(this.tcb, this.scope, null, current.children, this.generateGuard(current, switchValue));
const caseValue = tcbExpression(current.expression, this.tcb, caseScope);
return ts28.factory.createIfStatement(ts28.factory.createBinaryExpression(switchValue, ts28.SyntaxKind.EqualsEqualsEqualsToken, caseValue), ts28.factory.createBlock(caseScope.render()), this.generateCase(index + 1, switchValue, defaultCase));
}
generateGuard(node, switchValue) {
if (node.expression !== null) {
const expression = tcbExpression(node.expression, this.tcb, this.scope);
markIgnoreDiagnostics(expression);
return ts28.factory.createBinaryExpression(switchValue, ts28.SyntaxKind.EqualsEqualsEqualsToken, expression);
}
let guard = null;
for (const current of this.block.cases) {
if (current.expression === null) {
continue;
}
const expression = tcbExpression(current.expression, this.tcb, this.scope);
markIgnoreDiagnostics(expression);
const comparison = ts28.factory.createBinaryExpression(switchValue, ts28.SyntaxKind.ExclamationEqualsEqualsToken, expression);
if (guard === null) {
guard = comparison;
} else {
guard = ts28.factory.createBinaryExpression(guard, ts28.SyntaxKind.AmpersandAmpersandToken, comparison);
}
}
return guard;
}
};
var TcbForOfOp = class extends TcbOp {
constructor(tcb, scope, block) {
super();
this.tcb = tcb;
this.scope = scope;
this.block = block;
}
get optional() {
return false;
}
execute() {
const loopScope = Scope.forNodes(this.tcb, this.scope, this.block, this.block.children, null);
const initializerId = loopScope.resolve(this.block.item);
if (!ts28.isIdentifier(initializerId)) {
throw new Error(`Could not resolve for loop variable ${this.block.item.name} to an identifier`);
}
const initializer = ts28.factory.createVariableDeclarationList([ts28.factory.createVariableDeclaration(initializerId)], ts28.NodeFlags.Const);
addParseSpanInfo(initializer, this.block.item.keySpan);
const expression = ts28.factory.createNonNullExpression(tcbExpression(this.block.expression, this.tcb, loopScope));
const trackTranslator = new TcbForLoopTrackTranslator(this.tcb, loopScope, this.block);
const trackExpression = trackTranslator.translate(this.block.trackBy);
const statements = [
...loopScope.render(),
ts28.factory.createExpressionStatement(trackExpression)
];
this.scope.addStatement(ts28.factory.createForOfStatement(void 0, initializer, expression, ts28.factory.createBlock(statements)));
return null;
}
};
var INFER_TYPE_FOR_CIRCULAR_OP_EXPR = ts28.factory.createNonNullExpression(ts28.factory.createNull());
var Context = class {
constructor(env, domSchemaChecker, oobRecorder, id, boundTarget, pipes, schemas, hostIsStandalone, hostPreserveWhitespaces) {
this.env = env;
this.domSchemaChecker = domSchemaChecker;
this.oobRecorder = oobRecorder;
this.id = id;
this.boundTarget = boundTarget;
this.pipes = pipes;
this.schemas = schemas;
this.hostIsStandalone = hostIsStandalone;
this.hostPreserveWhitespaces = hostPreserveWhitespaces;
this.nextId = 1;
}
allocateId() {
return ts28.factory.createIdentifier(`_t${this.nextId++}`);
}
getPipeByName(name) {
if (!this.pipes.has(name)) {
return null;
}
return this.pipes.get(name);
}
};
var _Scope = class {
constructor(tcb, parent = null, guard = null) {
this.tcb = tcb;
this.parent = parent;
this.guard = guard;
this.opQueue = [];
this.elementOpMap = /* @__PURE__ */ new Map();
this.directiveOpMap = /* @__PURE__ */ new Map();
this.referenceOpMap = /* @__PURE__ */ new Map();
this.templateCtxOpMap = /* @__PURE__ */ new Map();
this.varMap = /* @__PURE__ */ new Map();
this.statements = [];
}
static forNodes(tcb, parentScope, scopedNode, children, guard) {
const scope = new _Scope(tcb, parentScope, guard);
if (parentScope === null && tcb.env.config.enableTemplateTypeChecker) {
scope.opQueue.push(new TcbComponentContextCompletionOp(scope));
}
if (scopedNode instanceof TmplAstTemplate2) {
const varMap = /* @__PURE__ */ new Map();
for (const v of scopedNode.variables) {
if (!varMap.has(v.name)) {
varMap.set(v.name, v);
} else {
const firstDecl = varMap.get(v.name);
tcb.oobRecorder.duplicateTemplateVar(tcb.id, v, firstDecl);
}
this.registerVariable(scope, v, new TcbTemplateVariableOp(tcb, scope, scopedNode, v));
}
} else if (scopedNode instanceof TmplAstIfBlockBranch) {
const { expression, expressionAlias } = scopedNode;
if (expression !== null && expressionAlias !== null) {
this.registerVariable(scope, expressionAlias, new TcbBlockVariableOp(tcb, scope, tcbExpression(expression, tcb, scope), expressionAlias));
}
} else if (scopedNode instanceof TmplAstForLoopBlock2) {
const loopInitializer = tcb.allocateId();
addParseSpanInfo(loopInitializer, scopedNode.item.sourceSpan);
scope.varMap.set(scopedNode.item, loopInitializer);
for (const [name, variable] of Object.entries(scopedNode.contextVariables)) {
if (!this.forLoopContextVariableTypes.has(name)) {
throw new Error(`Unrecognized for loop context variable ${name}`);
}
const type = ts28.factory.createKeywordTypeNode(this.forLoopContextVariableTypes.get(name));
this.registerVariable(scope, variable, new TcbBlockImplicitVariableOp(tcb, scope, type, variable));
}
}
for (const node of children) {
scope.appendNode(node);
}
return scope;
}
static registerVariable(scope, variable, op) {
const opIndex = scope.opQueue.push(op) - 1;
scope.varMap.set(variable, opIndex);
}
resolve(node, directive) {
const res = this.resolveLocal(node, directive);
if (res !== null) {
let clone;
if (ts28.isIdentifier(res)) {
clone = ts28.factory.createIdentifier(res.text);
} else if (ts28.isNonNullExpression(res)) {
clone = ts28.factory.createNonNullExpression(res.expression);
} else {
throw new Error(`Could not resolve ${node} to an Identifier or a NonNullExpression`);
}
ts28.setOriginalNode(clone, res);
clone.parent = clone.parent;
return ts28.setSyntheticTrailingComments(clone, []);
} else if (this.parent !== null) {
return this.parent.resolve(node, directive);
} else {
throw new Error(`Could not resolve ${node} / ${directive}`);
}
}
addStatement(stmt) {
this.statements.push(stmt);
}
render() {
for (let i = 0; i < this.opQueue.length; i++) {
const skipOptional = !this.tcb.env.config.enableTemplateTypeChecker;
this.executeOp(i, skipOptional);
}
return this.statements;
}
guards() {
let parentGuards = null;
if (this.parent !== null) {
parentGuards = this.parent.guards();
}
if (this.guard === null) {
return parentGuards;
} else if (parentGuards === null) {
return this.guard;
} else {
return ts28.factory.createBinaryExpression(parentGuards, ts28.SyntaxKind.AmpersandAmpersandToken, this.guard);
}
}
resolveLocal(ref, directive) {
if (ref instanceof TmplAstReference3 && this.referenceOpMap.has(ref)) {
return this.resolveOp(this.referenceOpMap.get(ref));
} else if (ref instanceof TmplAstVariable2 && this.varMap.has(ref)) {
const opIndexOrNode = this.varMap.get(ref);
return typeof opIndexOrNode === "number" ? this.resolveOp(opIndexOrNode) : opIndexOrNode;
} else if (ref instanceof TmplAstTemplate2 && directive === void 0 && this.templateCtxOpMap.has(ref)) {
return this.resolveOp(this.templateCtxOpMap.get(ref));
} else if ((ref instanceof TmplAstElement3 || ref instanceof TmplAstTemplate2) && directive !== void 0 && this.directiveOpMap.has(ref)) {
const dirMap = this.directiveOpMap.get(ref);
if (dirMap.has(directive)) {
return this.resolveOp(dirMap.get(directive));
} else {
return null;
}
} else if (ref instanceof TmplAstElement3 && this.elementOpMap.has(ref)) {
return this.resolveOp(this.elementOpMap.get(ref));
} else {
return null;
}
}
resolveOp(opIndex) {
const res = this.executeOp(opIndex, false);
if (res === null) {
throw new Error(`Error resolving operation, got null`);
}
return res;
}
executeOp(opIndex, skipOptional) {
const op = this.opQueue[opIndex];
if (!(op instanceof TcbOp)) {
return op;
}
if (skipOptional && op.optional) {
return null;
}
this.opQueue[opIndex] = op.circularFallback();
const res = op.execute();
this.opQueue[opIndex] = res;
return res;
}
appendNode(node) {
if (node instanceof TmplAstElement3) {
const opIndex = this.opQueue.push(new TcbElementOp(this.tcb, this, node)) - 1;
this.elementOpMap.set(node, opIndex);
if (this.tcb.env.config.controlFlowPreventingContentProjection !== "suppress") {
this.appendContentProjectionCheckOp(node);
}
this.appendDirectivesAndInputsOfNode(node);
this.appendOutputsOfNode(node);
this.appendChildren(node);
this.checkAndAppendReferencesOfNode(node);
} else if (node instanceof TmplAstTemplate2) {
this.appendDirectivesAndInputsOfNode(node);
this.appendOutputsOfNode(node);
const ctxIndex = this.opQueue.push(new TcbTemplateContextOp(this.tcb, this)) - 1;
this.templateCtxOpMap.set(node, ctxIndex);
if (this.tcb.env.config.checkTemplateBodies) {
this.opQueue.push(new TcbTemplateBodyOp(this.tcb, this, node));
} else if (this.tcb.env.config.alwaysCheckSchemaInTemplateBodies) {
this.appendDeepSchemaChecks(node.children);
}
this.checkAndAppendReferencesOfNode(node);
} else if (node instanceof TmplAstDeferredBlock) {
this.appendDeferredBlock(node);
} else if (node instanceof TmplAstIfBlock) {
this.opQueue.push(new TcbIfOp(this.tcb, this, node));
} else if (node instanceof TmplAstSwitchBlock) {
this.opQueue.push(new TcbExpressionOp(this.tcb, this, node.expression), new TcbSwitchOp(this.tcb, this, node));
} else if (node instanceof TmplAstForLoopBlock2) {
this.opQueue.push(new TcbForOfOp(this.tcb, this, node));
node.empty && this.appendChildren(node.empty);
} else if (node instanceof TmplAstBoundText) {
this.opQueue.push(new TcbExpressionOp(this.tcb, this, node.value));
} else if (node instanceof TmplAstIcu) {
this.appendIcuExpressions(node);
}
}
appendChildren(node) {
for (const child of node.children) {
this.appendNode(child);
}
}
checkAndAppendReferencesOfNode(node) {
for (const ref of node.references) {
const target = this.tcb.boundTarget.getReferenceTarget(ref);
let ctxIndex;
if (target === null) {
this.tcb.oobRecorder.missingReferenceTarget(this.tcb.id, ref);
ctxIndex = this.opQueue.push(new TcbInvalidReferenceOp(this.tcb, this)) - 1;
} else if (target instanceof TmplAstTemplate2 || target instanceof TmplAstElement3) {
ctxIndex = this.opQueue.push(new TcbReferenceOp(this.tcb, this, ref, node, target)) - 1;
} else {
ctxIndex = this.opQueue.push(new TcbReferenceOp(this.tcb, this, ref, node, target.directive)) - 1;
}
this.referenceOpMap.set(ref, ctxIndex);
}
}
appendDirectivesAndInputsOfNode(node) {
const claimedInputs = /* @__PURE__ */ new Set();
const directives = this.tcb.boundTarget.getDirectivesOfNode(node);
if (directives === null || directives.length === 0) {
if (node instanceof TmplAstElement3) {
this.opQueue.push(new TcbUnclaimedInputsOp(this.tcb, this, node, claimedInputs));
this.opQueue.push(new TcbDomSchemaCheckerOp(this.tcb, node, true, claimedInputs));
}
return;
} else {
if (node instanceof TmplAstElement3) {
const isDeferred = this.tcb.boundTarget.isDeferred(node);
if (!isDeferred && directives.some((dirMeta) => dirMeta.isExplicitlyDeferred)) {
this.tcb.oobRecorder.deferredComponentUsedEagerly(this.tcb.id, node);
}
}
}
const dirMap = /* @__PURE__ */ new Map();
for (const dir of directives) {
let directiveOp;
const host = this.tcb.env.reflector;
const dirRef = dir.ref;
if (!dir.isGeneric) {
directiveOp = new TcbNonGenericDirectiveTypeOp(this.tcb, this, node, dir);
} else if (!requiresInlineTypeCtor(dirRef.node, host, this.tcb.env) || this.tcb.env.config.useInlineTypeConstructors) {
directiveOp = new TcbDirectiveCtorOp(this.tcb, this, node, dir);
} else {
directiveOp = new TcbGenericDirectiveTypeWithAnyParamsOp(this.tcb, this, node, dir);
}
const dirIndex = this.opQueue.push(directiveOp) - 1;
dirMap.set(dir, dirIndex);
this.opQueue.push(new TcbDirectiveInputsOp(this.tcb, this, node, dir));
}
this.directiveOpMap.set(node, dirMap);
if (node instanceof TmplAstElement3) {
for (const dir of directives) {
for (const propertyName of dir.inputs.propertyNames) {
claimedInputs.add(propertyName);
}
}
this.opQueue.push(new TcbUnclaimedInputsOp(this.tcb, this, node, claimedInputs));
const checkElement = directives.length === 0;
this.opQueue.push(new TcbDomSchemaCheckerOp(this.tcb, node, checkElement, claimedInputs));
}
}
appendOutputsOfNode(node) {
const claimedOutputs = /* @__PURE__ */ new Set();
const directives = this.tcb.boundTarget.getDirectivesOfNode(node);
if (directives === null || directives.length === 0) {
if (node instanceof TmplAstElement3) {
this.opQueue.push(new TcbUnclaimedOutputsOp(this.tcb, this, node, claimedOutputs));
}
return;
}
for (const dir of directives) {
this.opQueue.push(new TcbDirectiveOutputsOp(this.tcb, this, node, dir));
}
if (node instanceof TmplAstElement3) {
for (const dir of directives) {
for (const outputProperty of dir.outputs.propertyNames) {
claimedOutputs.add(outputProperty);
}
}
this.opQueue.push(new TcbUnclaimedOutputsOp(this.tcb, this, node, claimedOutputs));
}
}
appendDeepSchemaChecks(nodes) {
for (const node of nodes) {
if (!(node instanceof TmplAstElement3 || node instanceof TmplAstTemplate2)) {
continue;
}
if (node instanceof TmplAstElement3) {
const claimedInputs = /* @__PURE__ */ new Set();
const directives = this.tcb.boundTarget.getDirectivesOfNode(node);
let hasDirectives;
if (directives === null || directives.length === 0) {
hasDirectives = false;
} else {
hasDirectives = true;
for (const dir of directives) {
for (const propertyName of dir.inputs.propertyNames) {
claimedInputs.add(propertyName);
}
}
}
this.opQueue.push(new TcbDomSchemaCheckerOp(this.tcb, node, !hasDirectives, claimedInputs));
}
this.appendDeepSchemaChecks(node.children);
}
}
appendIcuExpressions(node) {
for (const variable of Object.values(node.vars)) {
this.opQueue.push(new TcbExpressionOp(this.tcb, this, variable.value));
}
for (const placeholder of Object.values(node.placeholders)) {
if (placeholder instanceof TmplAstBoundText) {
this.opQueue.push(new TcbExpressionOp(this.tcb, this, placeholder.value));
}
}
}
appendContentProjectionCheckOp(root) {
var _a;
const meta = ((_a = this.tcb.boundTarget.getDirectivesOfNode(root)) == null ? void 0 : _a.find((meta2) => meta2.isComponent)) || null;
if (meta !== null && meta.ngContentSelectors !== null && meta.ngContentSelectors.length > 0) {
const selectors = meta.ngContentSelectors;
if (selectors.length > 1 || selectors.length === 1 && selectors[0] !== "*") {
this.opQueue.push(new TcbControlFlowContentProjectionOp(this.tcb, root, selectors, meta.name));
}
}
}
appendDeferredBlock(block) {
this.appendDeferredTriggers(block, block.triggers);
this.appendDeferredTriggers(block, block.prefetchTriggers);
this.appendChildren(block);
if (block.placeholder !== null) {
this.appendChildren(block.placeholder);
}
if (block.loading !== null) {
this.appendChildren(block.loading);
}
if (block.error !== null) {
this.appendChildren(block.error);
}
}
appendDeferredTriggers(block, triggers) {
if (triggers.when !== void 0) {
this.opQueue.push(new TcbExpressionOp(this.tcb, this, triggers.when.value));
}
if (triggers.hover !== void 0) {
this.appendReferenceBasedDeferredTrigger(block, triggers.hover);
}
if (triggers.interaction !== void 0) {
this.appendReferenceBasedDeferredTrigger(block, triggers.interaction);
}
if (triggers.viewport !== void 0) {
this.appendReferenceBasedDeferredTrigger(block, triggers.viewport);
}
}
appendReferenceBasedDeferredTrigger(block, trigger) {
if (this.tcb.boundTarget.getDeferredTriggerTarget(block, trigger) === null) {
this.tcb.oobRecorder.inaccessibleDeferredTriggerElement(this.tcb.id, trigger);
}
}
};
var Scope = _Scope;
(() => {
_Scope.forLoopContextVariableTypes = /* @__PURE__ */ new Map([
["$first", ts28.SyntaxKind.BooleanKeyword],
["$last", ts28.SyntaxKind.BooleanKeyword],
["$even", ts28.SyntaxKind.BooleanKeyword],
["$odd", ts28.SyntaxKind.BooleanKeyword],
["$index", ts28.SyntaxKind.NumberKeyword],
["$count", ts28.SyntaxKind.NumberKeyword]
]);
})();
function tcbThisParam(name, typeArguments) {
return ts28.factory.createParameterDeclaration(
void 0,
void 0,
"this",
void 0,
ts28.factory.createTypeReferenceNode(name, typeArguments),
void 0
);
}
function tcbExpression(ast, tcb, scope) {
const translator = new TcbExpressionTranslator(tcb, scope);
return translator.translate(ast);
}
var TcbExpressionTranslator = class {
constructor(tcb, scope) {
this.tcb = tcb;
this.scope = scope;
}
translate(ast) {
return astToTypescript(ast, (ast2) => this.resolve(ast2), this.tcb.env.config);
}
resolve(ast) {
if (ast instanceof PropertyRead4 && ast.receiver instanceof ImplicitReceiver4) {
return this.resolveTarget(ast);
} else if (ast instanceof PropertyWrite3 && ast.receiver instanceof ImplicitReceiver4) {
const target = this.resolveTarget(ast);
if (target === null) {
return null;
}
const expr = this.translate(ast.value);
const result = ts28.factory.createParenthesizedExpression(ts28.factory.createBinaryExpression(target, ts28.SyntaxKind.EqualsToken, expr));
addParseSpanInfo(result, ast.sourceSpan);
return result;
} else if (ast instanceof ImplicitReceiver4) {
return ts28.factory.createThis();
} else if (ast instanceof BindingPipe) {
const expr = this.translate(ast.exp);
const pipeMeta = this.tcb.getPipeByName(ast.name);
let pipe;
if (pipeMeta === null) {
this.tcb.oobRecorder.missingPipe(this.tcb.id, ast);
pipe = NULL_AS_ANY;
} else if (pipeMeta.isExplicitlyDeferred && this.tcb.boundTarget.getEagerlyUsedPipes().includes(ast.name)) {
this.tcb.oobRecorder.deferredPipeUsedEagerly(this.tcb.id, ast);
pipe = NULL_AS_ANY;
} else {
pipe = this.tcb.env.pipeInst(pipeMeta.ref);
}
const args = ast.args.map((arg) => this.translate(arg));
let methodAccess = ts28.factory.createPropertyAccessExpression(pipe, "transform");
addParseSpanInfo(methodAccess, ast.nameSpan);
if (!this.tcb.env.config.checkTypeOfPipes) {
methodAccess = ts28.factory.createAsExpression(methodAccess, ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
}
const result = ts28.factory.createCallExpression(
methodAccess,
void 0,
[expr, ...args]
);
addParseSpanInfo(result, ast.sourceSpan);
return result;
} else if ((ast instanceof Call2 || ast instanceof SafeCall) && (ast.receiver instanceof PropertyRead4 || ast.receiver instanceof SafePropertyRead3)) {
if (ast.receiver.receiver instanceof ImplicitReceiver4 && !(ast.receiver.receiver instanceof ThisReceiver) && ast.receiver.name === "$any" && ast.args.length === 1) {
const expr = this.translate(ast.args[0]);
const exprAsAny = ts28.factory.createAsExpression(expr, ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword));
const result = ts28.factory.createParenthesizedExpression(exprAsAny);
addParseSpanInfo(result, ast.sourceSpan);
return result;
}
const receiver = this.resolveTarget(ast);
if (receiver === null) {
return null;
}
const method = wrapForDiagnostics(receiver);
addParseSpanInfo(method, ast.receiver.nameSpan);
const args = ast.args.map((arg) => this.translate(arg));
const node = ts28.factory.createCallExpression(method, void 0, args);
addParseSpanInfo(node, ast.sourceSpan);
return node;
} else {
return null;
}
}
resolveTarget(ast) {
const binding = this.tcb.boundTarget.getExpressionTarget(ast);
if (binding === null) {
return null;
}
const expr = this.scope.resolve(binding);
addParseSpanInfo(expr, ast.sourceSpan);
return expr;
}
};
function tcbCallTypeCtor(dir, tcb, inputs) {
const typeCtor = tcb.env.typeCtorFor(dir);
const members = inputs.map((input) => {
const propertyName = ts28.factory.createStringLiteral(input.field);
if (input.type === "binding") {
const expr = widenBinding(input.expression, tcb);
const assignment = ts28.factory.createPropertyAssignment(propertyName, wrapForDiagnostics(expr));
addParseSpanInfo(assignment, input.sourceSpan);
return assignment;
} else {
return ts28.factory.createPropertyAssignment(propertyName, NULL_AS_ANY);
}
});
return ts28.factory.createCallExpression(
typeCtor,
void 0,
[ts28.factory.createObjectLiteralExpression(members)]
);
}
function getBoundAttributes(directive, node) {
const boundInputs = [];
const processAttribute = (attr) => {
if (attr instanceof TmplAstBoundAttribute && attr.type !== 0 && attr.type !== 5) {
return;
}
const inputs = directive.inputs.getByBindingPropertyName(attr.name);
if (inputs !== null) {
boundInputs.push({
attribute: attr,
inputs: inputs.map((input) => {
var _a;
return {
fieldName: input.classPropertyName,
required: input.required,
transformType: ((_a = input.transform) == null ? void 0 : _a.type) || null,
isSignal: input.isSignal
};
})
});
}
};
node.inputs.forEach(processAttribute);
node.attributes.forEach(processAttribute);
if (node instanceof TmplAstTemplate2) {
node.templateAttrs.forEach(processAttribute);
}
return boundInputs;
}
function translateInput(attr, tcb, scope) {
if (attr instanceof TmplAstBoundAttribute) {
return tcbExpression(attr.value, tcb, scope);
} else {
return ts28.factory.createStringLiteral(attr.value);
}
}
function widenBinding(expr, tcb) {
if (!tcb.env.config.checkTypeOfInputBindings) {
return tsCastToAny(expr);
} else if (!tcb.env.config.strictNullInputBindings) {
if (ts28.isObjectLiteralExpression(expr) || ts28.isArrayLiteralExpression(expr)) {
return expr;
} else {
return ts28.factory.createNonNullExpression(expr);
}
} else {
return expr;
}
}
var EVENT_PARAMETER = "$event";
function tcbCreateEventHandler(event, tcb, scope, eventType) {
const handler = tcbEventHandlerExpression(event.handler, tcb, scope);
let eventParamType;
if (eventType === 0) {
eventParamType = void 0;
} else if (eventType === 1) {
eventParamType = ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword);
} else {
eventParamType = eventType;
}
const guards = scope.guards();
let body = ts28.factory.createExpressionStatement(handler);
if (guards !== null) {
body = ts28.factory.createIfStatement(guards, body);
}
const eventParam = ts28.factory.createParameterDeclaration(
void 0,
void 0,
EVENT_PARAMETER,
void 0,
eventParamType
);
addExpressionIdentifier(eventParam, ExpressionIdentifier.EVENT_PARAMETER);
return ts28.factory.createArrowFunction(
void 0,
void 0,
[eventParam],
ts28.factory.createKeywordTypeNode(ts28.SyntaxKind.AnyKeyword),
void 0,
ts28.factory.createBlock([body])
);
}
function tcbEventHandlerExpression(ast, tcb, scope) {
const translator = new TcbEventHandlerTranslator(tcb, scope);
return translator.translate(ast);
}
function isSplitTwoWayBinding(inputName, output, inputs, tcb) {
const input = inputs.find((input2) => input2.name === inputName);
if (input === void 0 || input.sourceSpan !== output.sourceSpan) {
return false;
}
const inputConsumer = tcb.boundTarget.getConsumerOfBinding(input);
const outputConsumer = tcb.boundTarget.getConsumerOfBinding(output);
if (outputConsumer === null || inputConsumer.ref === void 0 || outputConsumer instanceof TmplAstTemplate2) {
return false;
}
if (outputConsumer instanceof TmplAstElement3) {
tcb.oobRecorder.splitTwoWayBinding(tcb.id, input, output, inputConsumer.ref.node, outputConsumer);
return true;
} else if (outputConsumer.ref !== inputConsumer.ref) {
tcb.oobRecorder.splitTwoWayBinding(tcb.id, input, output, inputConsumer.ref.node, outputConsumer.ref.node);
return true;
}
return false;
}
var TcbEventHandlerTranslator = class extends TcbExpressionTranslator {
resolve(ast) {
if (ast instanceof PropertyRead4 && ast.receiver instanceof ImplicitReceiver4 && !(ast.receiver instanceof ThisReceiver) && ast.name === EVENT_PARAMETER) {
const event = ts28.factory.createIdentifier(EVENT_PARAMETER);
addParseSpanInfo(event, ast.nameSpan);
return event;
}
return super.resolve(ast);
}
};
var TcbForLoopTrackTranslator = class extends TcbExpressionTranslator {
constructor(tcb, scope, block) {
super(tcb, scope);
this.block = block;
}
resolve(ast) {
if (ast instanceof PropertyRead4 && ast.receiver instanceof ImplicitReceiver4) {
const target = this.tcb.boundTarget.getExpressionTarget(ast);
if (target !== null && target !== this.block.item && target !== this.block.contextVariables.$index) {
this.tcb.oobRecorder.illegalForLoopTrackAccess(this.tcb.id, this.block, ast);
}
}
return super.resolve(ast);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/type_check_file.mjs
import ts29 from "typescript";
var TypeCheckFile = class extends Environment {
constructor(fileName, config, refEmitter, reflector, compilerHost) {
super(config, new ImportManager(new NoopImportRewriter(), "i"), refEmitter, reflector, ts29.createSourceFile(compilerHost.getCanonicalFileName(fileName), "", ts29.ScriptTarget.Latest, true));
this.fileName = fileName;
this.nextTcbId = 1;
this.tcbStatements = [];
}
addTypeCheckBlock(ref, meta, domSchemaChecker, oobRecorder, genericContextBehavior) {
const fnId = ts29.factory.createIdentifier(`_tcb${this.nextTcbId++}`);
const fn = generateTypeCheckBlock(this, ref, fnId, meta, domSchemaChecker, oobRecorder, genericContextBehavior);
this.tcbStatements.push(fn);
}
render(removeComments) {
ensureTypeCheckFilePreparationImports(this);
let source = this.importManager.getAllImports(this.contextFile.fileName).map((i) => `import * as ${i.qualifier.text} from '${i.specifier}';`).join("\n") + "\n\n";
const printer = ts29.createPrinter({ removeComments });
source += "\n";
for (const stmt of this.pipeInstStatements) {
source += printer.printNode(ts29.EmitHint.Unspecified, stmt, this.contextFile) + "\n";
}
for (const stmt of this.typeCtorStatements) {
source += printer.printNode(ts29.EmitHint.Unspecified, stmt, this.contextFile) + "\n";
}
source += "\n";
for (const stmt of this.tcbStatements) {
source += printer.printNode(ts29.EmitHint.Unspecified, stmt, this.contextFile) + "\n";
}
source += "\nexport const IS_A_MODULE = true;\n";
return source;
}
getPreludeStatements() {
return [];
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/context.mjs
var InliningMode;
(function(InliningMode2) {
InliningMode2[InliningMode2["InlineOps"] = 0] = "InlineOps";
InliningMode2[InliningMode2["Error"] = 1] = "Error";
})(InliningMode || (InliningMode = {}));
var TypeCheckContextImpl = class {
constructor(config, compilerHost, refEmitter, reflector, host, inlining, perf) {
this.config = config;
this.compilerHost = compilerHost;
this.refEmitter = refEmitter;
this.reflector = reflector;
this.host = host;
this.inlining = inlining;
this.perf = perf;
this.fileMap = /* @__PURE__ */ new Map();
this.opMap = /* @__PURE__ */ new Map();
this.typeCtorPending = /* @__PURE__ */ new Set();
if (inlining === InliningMode.Error && config.useInlineTypeConstructors) {
throw new Error(`AssertionError: invalid inlining configuration.`);
}
}
addTemplate(ref, binder, template, pipes, schemas, sourceMapping, file, parseErrors, isStandalone, preserveWhitespaces) {
if (!this.host.shouldCheckComponent(ref.node)) {
return;
}
const fileData = this.dataForFile(ref.node.getSourceFile());
const shimData = this.pendingShimForComponent(ref.node);
const templateId = fileData.sourceManager.getTemplateId(ref.node);
const templateDiagnostics = [];
if (parseErrors !== null) {
templateDiagnostics.push(...this.getTemplateDiagnostics(parseErrors, templateId, sourceMapping));
}
const boundTarget = binder.bind({ template });
if (this.inlining === InliningMode.InlineOps) {
for (const dir of boundTarget.getUsedDirectives()) {
const dirRef = dir.ref;
const dirNode = dirRef.node;
if (!dir.isGeneric || !requiresInlineTypeCtor(dirNode, this.reflector, shimData.file)) {
continue;
}
this.addInlineTypeCtor(fileData, dirNode.getSourceFile(), dirRef, {
fnName: "ngTypeCtor",
body: !dirNode.getSourceFile().isDeclarationFile,
fields: {
inputs: dir.inputs,
queries: dir.queries
},
coercedInputFields: dir.coercedInputFields
});
}
}
shimData.templates.set(templateId, {
template,
boundTarget,
templateDiagnostics
});
const usedPipes = [];
for (const name of boundTarget.getUsedPipes()) {
if (!pipes.has(name)) {
continue;
}
usedPipes.push(pipes.get(name).ref);
}
const inliningRequirement = requiresInlineTypeCheckBlock(ref, shimData.file, usedPipes, this.reflector);
if (this.inlining === InliningMode.Error && inliningRequirement === TcbInliningRequirement.MustInline) {
shimData.oobRecorder.requiresInlineTcb(templateId, ref.node);
this.perf.eventCount(PerfEvent.SkipGenerateTcbNoInline);
return;
}
const meta = {
id: fileData.sourceManager.captureSource(ref.node, sourceMapping, file),
boundTarget,
pipes,
schemas,
isStandalone,
preserveWhitespaces
};
this.perf.eventCount(PerfEvent.GenerateTcb);
if (inliningRequirement !== TcbInliningRequirement.None && this.inlining === InliningMode.InlineOps) {
this.addInlineTypeCheckBlock(fileData, shimData, ref, meta);
} else if (inliningRequirement === TcbInliningRequirement.ShouldInlineForGenericBounds && this.inlining === InliningMode.Error) {
shimData.file.addTypeCheckBlock(ref, meta, shimData.domSchemaChecker, shimData.oobRecorder, TcbGenericContextBehavior.FallbackToAny);
} else {
shimData.file.addTypeCheckBlock(ref, meta, shimData.domSchemaChecker, shimData.oobRecorder, TcbGenericContextBehavior.UseEmitter);
}
}
addInlineTypeCtor(fileData, sf, ref, ctorMeta) {
if (this.typeCtorPending.has(ref.node)) {
return;
}
this.typeCtorPending.add(ref.node);
if (!this.opMap.has(sf)) {
this.opMap.set(sf, []);
}
const ops = this.opMap.get(sf);
ops.push(new TypeCtorOp(ref, this.reflector, ctorMeta));
fileData.hasInlines = true;
}
transform(sf) {
if (!this.opMap.has(sf)) {
return null;
}
const importManager = new ImportManager(new NoopImportRewriter(), "_i");
const ops = this.opMap.get(sf).sort(orderOps);
const textParts = splitStringAtPoints(sf.text, ops.map((op) => op.splitPoint));
const printer = ts30.createPrinter({ omitTrailingSemicolon: true });
let code = textParts[0];
ops.forEach((op, idx) => {
const text = op.execute(importManager, sf, this.refEmitter, printer);
code += "\n\n" + text + textParts[idx + 1];
});
let imports = importManager.getAllImports(sf.fileName).map((i) => `import * as ${i.qualifier.text} from '${i.specifier}';`).join("\n");
code = imports + "\n" + code;
return code;
}
finalize() {
const updates = /* @__PURE__ */ new Map();
for (const originalSf of this.opMap.keys()) {
const newText = this.transform(originalSf);
if (newText !== null) {
updates.set(absoluteFromSourceFile(originalSf), {
newText,
originalFile: originalSf
});
}
}
for (const [sfPath, pendingFileData] of this.fileMap) {
for (const pendingShimData of pendingFileData.shimData.values()) {
this.host.recordShimData(sfPath, {
genesisDiagnostics: [
...pendingShimData.domSchemaChecker.diagnostics,
...pendingShimData.oobRecorder.diagnostics
],
hasInlines: pendingFileData.hasInlines,
path: pendingShimData.file.fileName,
templates: pendingShimData.templates
});
const sfText = pendingShimData.file.render(false);
updates.set(pendingShimData.file.fileName, {
newText: sfText,
originalFile: null
});
}
}
return updates;
}
addInlineTypeCheckBlock(fileData, shimData, ref, tcbMeta) {
const sf = ref.node.getSourceFile();
if (!this.opMap.has(sf)) {
this.opMap.set(sf, []);
}
const ops = this.opMap.get(sf);
ops.push(new InlineTcbOp(ref, tcbMeta, this.config, this.reflector, shimData.domSchemaChecker, shimData.oobRecorder));
fileData.hasInlines = true;
}
pendingShimForComponent(node) {
const fileData = this.dataForFile(node.getSourceFile());
const shimPath = TypeCheckShimGenerator.shimFor(absoluteFromSourceFile(node.getSourceFile()));
if (!fileData.shimData.has(shimPath)) {
fileData.shimData.set(shimPath, {
domSchemaChecker: new RegistryDomSchemaChecker(fileData.sourceManager),
oobRecorder: new OutOfBandDiagnosticRecorderImpl(fileData.sourceManager),
file: new TypeCheckFile(shimPath, this.config, this.refEmitter, this.reflector, this.compilerHost),
templates: /* @__PURE__ */ new Map()
});
}
return fileData.shimData.get(shimPath);
}
dataForFile(sf) {
const sfPath = absoluteFromSourceFile(sf);
if (!this.fileMap.has(sfPath)) {
const data = {
hasInlines: false,
sourceManager: this.host.getSourceManager(sfPath),
shimData: /* @__PURE__ */ new Map()
};
this.fileMap.set(sfPath, data);
}
return this.fileMap.get(sfPath);
}
getTemplateDiagnostics(parseErrors, templateId, sourceMapping) {
return parseErrors.map((error) => {
const span = error.span;
if (span.start.offset === span.end.offset) {
span.end.offset++;
}
return makeTemplateDiagnostic(templateId, sourceMapping, span, ts30.DiagnosticCategory.Error, ngErrorCode(ErrorCode.TEMPLATE_PARSE_ERROR), error.msg);
});
}
};
var InlineTcbOp = class {
constructor(ref, meta, config, reflector, domSchemaChecker, oobRecorder) {
this.ref = ref;
this.meta = meta;
this.config = config;
this.reflector = reflector;
this.domSchemaChecker = domSchemaChecker;
this.oobRecorder = oobRecorder;
}
get splitPoint() {
return this.ref.node.end + 1;
}
execute(im, sf, refEmitter, printer) {
const env = new Environment(this.config, im, refEmitter, this.reflector, sf);
const fnName = ts30.factory.createIdentifier(`_tcb_${this.ref.node.pos}`);
const fn = generateTypeCheckBlock(env, this.ref, fnName, this.meta, this.domSchemaChecker, this.oobRecorder, TcbGenericContextBehavior.CopyClassNodes);
return printer.printNode(ts30.EmitHint.Unspecified, fn, sf);
}
};
var TypeCtorOp = class {
constructor(ref, reflector, meta) {
this.ref = ref;
this.reflector = reflector;
this.meta = meta;
}
get splitPoint() {
return this.ref.node.end - 1;
}
execute(im, sf, refEmitter, printer) {
const emitEnv = new ReferenceEmitEnvironment(im, refEmitter, this.reflector, sf);
const tcb = generateInlineTypeCtor(emitEnv, this.ref.node, this.meta);
return printer.printNode(ts30.EmitHint.Unspecified, tcb, sf);
}
};
function orderOps(op1, op2) {
return op1.splitPoint - op2.splitPoint;
}
function splitStringAtPoints(str, points) {
const splits = [];
let start = 0;
for (let i = 0; i < points.length; i++) {
const point = points[i];
splits.push(str.substring(start, point));
start = point;
}
splits.push(str.substring(start));
return splits;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/source.mjs
import { ParseLocation, ParseSourceSpan } from "@angular/compiler";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/line_mappings.mjs
var LF_CHAR = 10;
var CR_CHAR = 13;
var LINE_SEP_CHAR = 8232;
var PARAGRAPH_CHAR = 8233;
function getLineAndCharacterFromPosition(lineStartsMap, position) {
const lineIndex = findClosestLineStartPosition(lineStartsMap, position);
return { character: position - lineStartsMap[lineIndex], line: lineIndex };
}
function computeLineStartsMap(text) {
const result = [0];
let pos = 0;
while (pos < text.length) {
const char = text.charCodeAt(pos++);
if (char === CR_CHAR) {
if (text.charCodeAt(pos) === LF_CHAR) {
pos++;
}
result.push(pos);
} else if (char === LF_CHAR || char === LINE_SEP_CHAR || char === PARAGRAPH_CHAR) {
result.push(pos);
}
}
result.push(pos);
return result;
}
function findClosestLineStartPosition(linesMap, position, low = 0, high = linesMap.length - 1) {
while (low <= high) {
const pivotIdx = Math.floor((low + high) / 2);
const pivotEl = linesMap[pivotIdx];
if (pivotEl === position) {
return pivotIdx;
} else if (position > pivotEl) {
low = pivotIdx + 1;
} else {
high = pivotIdx - 1;
}
}
return low - 1;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/source.mjs
var TemplateSource = class {
constructor(mapping, file) {
this.mapping = mapping;
this.file = file;
this.lineStarts = null;
}
toParseSourceSpan(start, end) {
const startLoc = this.toParseLocation(start);
const endLoc = this.toParseLocation(end);
return new ParseSourceSpan(startLoc, endLoc);
}
toParseLocation(position) {
const lineStarts = this.acquireLineStarts();
const { line, character } = getLineAndCharacterFromPosition(lineStarts, position);
return new ParseLocation(this.file, position, line, character);
}
acquireLineStarts() {
if (this.lineStarts === null) {
this.lineStarts = computeLineStartsMap(this.file.content);
}
return this.lineStarts;
}
};
var TemplateSourceManager = class {
constructor() {
this.templateSources = /* @__PURE__ */ new Map();
}
getTemplateId(node) {
return getTemplateId(node);
}
captureSource(node, mapping, file) {
const id = getTemplateId(node);
this.templateSources.set(id, new TemplateSource(mapping, file));
return id;
}
getSourceMapping(id) {
if (!this.templateSources.has(id)) {
throw new Error(`Unexpected unknown template ID: ${id}`);
}
return this.templateSources.get(id).mapping;
}
toParseSourceSpan(id, span) {
if (!this.templateSources.has(id)) {
return null;
}
const templateSource = this.templateSources.get(id);
return templateSource.toParseSourceSpan(span.start, span.end);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/template_symbol_builder.mjs
import { AST, ASTWithSource as ASTWithSource3, BindingPipe as BindingPipe2, PropertyRead as PropertyRead5, PropertyWrite as PropertyWrite4, R3Identifiers as R3Identifiers4, SafePropertyRead as SafePropertyRead4, TmplAstBoundAttribute as TmplAstBoundAttribute2, TmplAstBoundEvent, TmplAstElement as TmplAstElement4, TmplAstReference as TmplAstReference4, TmplAstTemplate as TmplAstTemplate3, TmplAstTextAttribute as TmplAstTextAttribute3, TmplAstVariable as TmplAstVariable3 } from "@angular/compiler";
import ts31 from "typescript";
var SymbolBuilder = class {
constructor(tcbPath, tcbIsShim, typeCheckBlock, templateData, componentScopeReader, getTypeChecker) {
this.tcbPath = tcbPath;
this.tcbIsShim = tcbIsShim;
this.typeCheckBlock = typeCheckBlock;
this.templateData = templateData;
this.componentScopeReader = componentScopeReader;
this.getTypeChecker = getTypeChecker;
this.symbolCache = /* @__PURE__ */ new Map();
}
getSymbol(node) {
if (this.symbolCache.has(node)) {
return this.symbolCache.get(node);
}
let symbol = null;
if (node instanceof TmplAstBoundAttribute2 || node instanceof TmplAstTextAttribute3) {
symbol = this.getSymbolOfInputBinding(node);
} else if (node instanceof TmplAstBoundEvent) {
symbol = this.getSymbolOfBoundEvent(node);
} else if (node instanceof TmplAstElement4) {
symbol = this.getSymbolOfElement(node);
} else if (node instanceof TmplAstTemplate3) {
symbol = this.getSymbolOfAstTemplate(node);
} else if (node instanceof TmplAstVariable3) {
symbol = this.getSymbolOfVariable(node);
} else if (node instanceof TmplAstReference4) {
symbol = this.getSymbolOfReference(node);
} else if (node instanceof BindingPipe2) {
symbol = this.getSymbolOfPipe(node);
} else if (node instanceof AST) {
symbol = this.getSymbolOfTemplateExpression(node);
} else {
}
this.symbolCache.set(node, symbol);
return symbol;
}
getSymbolOfAstTemplate(template) {
const directives = this.getDirectivesOfNode(template);
return { kind: SymbolKind.Template, directives, templateNode: template };
}
getSymbolOfElement(element) {
var _a;
const elementSourceSpan = (_a = element.startSourceSpan) != null ? _a : element.sourceSpan;
const node = findFirstMatchingNode(this.typeCheckBlock, { withSpan: elementSourceSpan, filter: ts31.isVariableDeclaration });
if (node === null) {
return null;
}
const symbolFromDeclaration = this.getSymbolOfTsNode(node);
if (symbolFromDeclaration === null || symbolFromDeclaration.tsSymbol === null) {
return null;
}
const directives = this.getDirectivesOfNode(element);
return {
...symbolFromDeclaration,
kind: SymbolKind.Element,
directives,
templateNode: element
};
}
getDirectivesOfNode(element) {
var _a;
const elementSourceSpan = (_a = element.startSourceSpan) != null ? _a : element.sourceSpan;
const tcbSourceFile = this.typeCheckBlock.getSourceFile();
const isDirectiveDeclaration = (node) => (ts31.isTypeNode(node) || ts31.isIdentifier(node)) && ts31.isVariableDeclaration(node.parent) && hasExpressionIdentifier(tcbSourceFile, node, ExpressionIdentifier.DIRECTIVE);
const nodes = findAllMatchingNodes(this.typeCheckBlock, { withSpan: elementSourceSpan, filter: isDirectiveDeclaration });
const symbols = [];
for (const node of nodes) {
const symbol = this.getSymbolOfTsNode(node.parent);
if (symbol === null || !isSymbolWithValueDeclaration(symbol.tsSymbol) || !ts31.isClassDeclaration(symbol.tsSymbol.valueDeclaration)) {
continue;
}
const meta = this.getDirectiveMeta(element, symbol.tsSymbol.valueDeclaration);
if (meta !== null && meta.selector !== null) {
const ref = new Reference(symbol.tsSymbol.valueDeclaration);
if (meta.hostDirectives !== null) {
this.addHostDirectiveSymbols(element, meta.hostDirectives, symbols);
}
const directiveSymbol = {
...symbol,
ref,
tsSymbol: symbol.tsSymbol,
selector: meta.selector,
isComponent: meta.isComponent,
ngModule: this.getDirectiveModule(symbol.tsSymbol.valueDeclaration),
kind: SymbolKind.Directive,
isStructural: meta.isStructural,
isInScope: true,
isHostDirective: false
};
symbols.push(directiveSymbol);
}
}
return symbols;
}
addHostDirectiveSymbols(host, hostDirectives, symbols) {
for (const current of hostDirectives) {
if (!ts31.isClassDeclaration(current.directive.node)) {
continue;
}
const symbol = this.getSymbolOfTsNode(current.directive.node);
const meta = this.getDirectiveMeta(host, current.directive.node);
if (meta !== null && symbol !== null && isSymbolWithValueDeclaration(symbol.tsSymbol)) {
if (meta.hostDirectives !== null) {
this.addHostDirectiveSymbols(host, meta.hostDirectives, symbols);
}
const directiveSymbol = {
...symbol,
isHostDirective: true,
ref: current.directive,
tsSymbol: symbol.tsSymbol,
exposedInputs: current.inputs,
exposedOutputs: current.outputs,
selector: meta.selector,
isComponent: meta.isComponent,
ngModule: this.getDirectiveModule(current.directive.node),
kind: SymbolKind.Directive,
isStructural: meta.isStructural,
isInScope: true
};
symbols.push(directiveSymbol);
}
}
}
getDirectiveMeta(host, directiveDeclaration) {
var _a;
let directives = this.templateData.boundTarget.getDirectivesOfNode(host);
const firstChild = host.children[0];
if (firstChild instanceof TmplAstElement4) {
const isMicrosyntaxTemplate = host instanceof TmplAstTemplate3 && sourceSpanEqual(firstChild.sourceSpan, host.sourceSpan);
if (isMicrosyntaxTemplate) {
const firstChildDirectives = this.templateData.boundTarget.getDirectivesOfNode(firstChild);
if (firstChildDirectives !== null && directives !== null) {
directives = directives.concat(firstChildDirectives);
} else {
directives = directives != null ? directives : firstChildDirectives;
}
}
}
if (directives === null) {
return null;
}
return (_a = directives.find((m) => m.ref.node === directiveDeclaration)) != null ? _a : null;
}
getDirectiveModule(declaration) {
const scope = this.componentScopeReader.getScopeForComponent(declaration);
if (scope === null || scope.kind !== ComponentScopeKind.NgModule) {
return null;
}
return scope.ngModule;
}
getSymbolOfBoundEvent(eventBinding) {
const consumer = this.templateData.boundTarget.getConsumerOfBinding(eventBinding);
if (consumer === null) {
return null;
}
let expectedAccess;
if (consumer instanceof TmplAstTemplate3 || consumer instanceof TmplAstElement4) {
expectedAccess = "addEventListener";
} else {
const bindingPropertyNames = consumer.outputs.getByBindingPropertyName(eventBinding.name);
if (bindingPropertyNames === null || bindingPropertyNames.length === 0) {
return null;
}
expectedAccess = bindingPropertyNames[0].classPropertyName;
}
function filter(n) {
if (!isAccessExpression(n)) {
return false;
}
if (ts31.isPropertyAccessExpression(n)) {
return n.name.getText() === expectedAccess;
} else {
return ts31.isStringLiteral(n.argumentExpression) && n.argumentExpression.text === expectedAccess;
}
}
const outputFieldAccesses = findAllMatchingNodes(this.typeCheckBlock, { withSpan: eventBinding.keySpan, filter });
const bindings = [];
for (const outputFieldAccess of outputFieldAccesses) {
if (consumer instanceof TmplAstTemplate3 || consumer instanceof TmplAstElement4) {
if (!ts31.isPropertyAccessExpression(outputFieldAccess)) {
continue;
}
const addEventListener = outputFieldAccess.name;
const tsSymbol = this.getTypeChecker().getSymbolAtLocation(addEventListener);
const tsType = this.getTypeChecker().getTypeAtLocation(addEventListener);
const positionInFile = this.getTcbPositionForNode(addEventListener);
const target = this.getSymbol(consumer);
if (target === null || tsSymbol === void 0) {
continue;
}
bindings.push({
kind: SymbolKind.Binding,
tsSymbol,
tsType,
target,
tcbLocation: {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile
}
});
} else {
if (!ts31.isElementAccessExpression(outputFieldAccess)) {
continue;
}
const tsSymbol = this.getTypeChecker().getSymbolAtLocation(outputFieldAccess.argumentExpression);
if (tsSymbol === void 0) {
continue;
}
const target = this.getDirectiveSymbolForAccessExpression(outputFieldAccess, consumer);
if (target === null) {
continue;
}
const positionInFile = this.getTcbPositionForNode(outputFieldAccess);
const tsType = this.getTypeChecker().getTypeAtLocation(outputFieldAccess);
bindings.push({
kind: SymbolKind.Binding,
tsSymbol,
tsType,
target,
tcbLocation: {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile
}
});
}
}
if (bindings.length === 0) {
return null;
}
return { kind: SymbolKind.Output, bindings };
}
getSymbolOfInputBinding(binding) {
var _a;
const consumer = this.templateData.boundTarget.getConsumerOfBinding(binding);
if (consumer === null) {
return null;
}
if (consumer instanceof TmplAstElement4 || consumer instanceof TmplAstTemplate3) {
const host = this.getSymbol(consumer);
return host !== null ? { kind: SymbolKind.DomBinding, host } : null;
}
const nodes = findAllMatchingNodes(this.typeCheckBlock, { withSpan: binding.sourceSpan, filter: isAssignment });
const bindings = [];
for (const node of nodes) {
if (!isAccessExpression(node.left)) {
continue;
}
const signalInputAssignment = unwrapSignalInputWriteTAccessor(node.left);
let symbolInfo = null;
if (signalInputAssignment !== null) {
const fieldSymbol = this.getSymbolOfTsNode(signalInputAssignment.fieldExpr);
const typeSymbol = this.getSymbolOfTsNode(signalInputAssignment.typeExpr);
symbolInfo = fieldSymbol === null || typeSymbol === null ? null : {
tcbLocation: fieldSymbol.tcbLocation,
tsSymbol: fieldSymbol.tsSymbol,
tsType: typeSymbol.tsType
};
} else {
symbolInfo = this.getSymbolOfTsNode(node.left);
}
if (symbolInfo === null || symbolInfo.tsSymbol === null) {
continue;
}
const target = this.getDirectiveSymbolForAccessExpression((_a = signalInputAssignment == null ? void 0 : signalInputAssignment.fieldExpr) != null ? _a : node.left, consumer);
if (target === null) {
continue;
}
bindings.push({
...symbolInfo,
tsSymbol: symbolInfo.tsSymbol,
kind: SymbolKind.Binding,
target
});
}
if (bindings.length === 0) {
return null;
}
return { kind: SymbolKind.Input, bindings };
}
getDirectiveSymbolForAccessExpression(fieldAccessExpr, { isComponent, selector, isStructural }) {
var _a;
const tsSymbol = this.getTypeChecker().getSymbolAtLocation(fieldAccessExpr.expression);
if ((tsSymbol == null ? void 0 : tsSymbol.declarations) === void 0 || tsSymbol.declarations.length === 0 || selector === null) {
return null;
}
const [declaration] = tsSymbol.declarations;
if (!ts31.isVariableDeclaration(declaration) || !hasExpressionIdentifier(
declaration.getSourceFile(),
(_a = declaration.type) != null ? _a : declaration.name,
ExpressionIdentifier.DIRECTIVE
)) {
return null;
}
const symbol = this.getSymbolOfTsNode(declaration);
if (symbol === null || !isSymbolWithValueDeclaration(symbol.tsSymbol) || !ts31.isClassDeclaration(symbol.tsSymbol.valueDeclaration)) {
return null;
}
const ref = new Reference(symbol.tsSymbol.valueDeclaration);
const ngModule = this.getDirectiveModule(symbol.tsSymbol.valueDeclaration);
return {
ref,
kind: SymbolKind.Directive,
tsSymbol: symbol.tsSymbol,
tsType: symbol.tsType,
tcbLocation: symbol.tcbLocation,
isComponent,
isStructural,
selector,
ngModule,
isHostDirective: false,
isInScope: true
};
}
getSymbolOfVariable(variable) {
const node = findFirstMatchingNode(this.typeCheckBlock, { withSpan: variable.sourceSpan, filter: ts31.isVariableDeclaration });
if (node === null) {
return null;
}
let nodeValueSymbol = null;
if (ts31.isForOfStatement(node.parent.parent)) {
nodeValueSymbol = this.getSymbolOfTsNode(node);
} else if (node.initializer !== void 0) {
nodeValueSymbol = this.getSymbolOfTsNode(node.initializer);
}
if (nodeValueSymbol === null) {
return null;
}
return {
tsType: nodeValueSymbol.tsType,
tsSymbol: nodeValueSymbol.tsSymbol,
initializerLocation: nodeValueSymbol.tcbLocation,
kind: SymbolKind.Variable,
declaration: variable,
localVarLocation: {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: this.getTcbPositionForNode(node.name)
}
};
}
getSymbolOfReference(ref) {
const target = this.templateData.boundTarget.getReferenceTarget(ref);
let node = findFirstMatchingNode(this.typeCheckBlock, { withSpan: ref.sourceSpan, filter: ts31.isVariableDeclaration });
if (node === null || target === null || node.initializer === void 0) {
return null;
}
const originalDeclaration = ts31.isParenthesizedExpression(node.initializer) && ts31.isAsExpression(node.initializer.expression) ? this.getTypeChecker().getSymbolAtLocation(node.name) : this.getTypeChecker().getSymbolAtLocation(node.initializer);
if (originalDeclaration === void 0 || originalDeclaration.valueDeclaration === void 0) {
return null;
}
const symbol = this.getSymbolOfTsNode(originalDeclaration.valueDeclaration);
if (symbol === null || symbol.tsSymbol === null) {
return null;
}
const referenceVarTcbLocation = {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile: this.getTcbPositionForNode(node)
};
if (target instanceof TmplAstTemplate3 || target instanceof TmplAstElement4) {
return {
kind: SymbolKind.Reference,
tsSymbol: symbol.tsSymbol,
tsType: symbol.tsType,
target,
declaration: ref,
targetLocation: symbol.tcbLocation,
referenceVarLocation: referenceVarTcbLocation
};
} else {
if (!ts31.isClassDeclaration(target.directive.ref.node)) {
return null;
}
return {
kind: SymbolKind.Reference,
tsSymbol: symbol.tsSymbol,
tsType: symbol.tsType,
declaration: ref,
target: target.directive.ref.node,
targetLocation: symbol.tcbLocation,
referenceVarLocation: referenceVarTcbLocation
};
}
}
getSymbolOfPipe(expression) {
const methodAccess = findFirstMatchingNode(this.typeCheckBlock, { withSpan: expression.nameSpan, filter: ts31.isPropertyAccessExpression });
if (methodAccess === null) {
return null;
}
const pipeVariableNode = methodAccess.expression;
const pipeDeclaration = this.getTypeChecker().getSymbolAtLocation(pipeVariableNode);
if (pipeDeclaration === void 0 || pipeDeclaration.valueDeclaration === void 0) {
return null;
}
const pipeInstance = this.getSymbolOfTsNode(pipeDeclaration.valueDeclaration);
if (pipeInstance === null || !isSymbolWithValueDeclaration(pipeInstance.tsSymbol)) {
return null;
}
const symbolInfo = this.getSymbolOfTsNode(methodAccess);
if (symbolInfo === null) {
return null;
}
return {
kind: SymbolKind.Pipe,
...symbolInfo,
classSymbol: {
...pipeInstance,
tsSymbol: pipeInstance.tsSymbol
}
};
}
getSymbolOfTemplateExpression(expression) {
if (expression instanceof ASTWithSource3) {
expression = expression.ast;
}
const expressionTarget = this.templateData.boundTarget.getExpressionTarget(expression);
if (expressionTarget !== null) {
return this.getSymbol(expressionTarget);
}
let withSpan = expression.sourceSpan;
if (expression instanceof PropertyWrite4) {
withSpan = expression.nameSpan;
}
let node = null;
if (expression instanceof PropertyRead5) {
node = findFirstMatchingNode(this.typeCheckBlock, { withSpan, filter: ts31.isPropertyAccessExpression });
}
if (node === null) {
node = findFirstMatchingNode(this.typeCheckBlock, { withSpan, filter: anyNodeFilter });
}
if (node === null) {
return null;
}
while (ts31.isParenthesizedExpression(node)) {
node = node.expression;
}
if (expression instanceof SafePropertyRead4 && ts31.isConditionalExpression(node)) {
const whenTrueSymbol = this.getSymbolOfTsNode(node.whenTrue);
if (whenTrueSymbol === null) {
return null;
}
return {
...whenTrueSymbol,
kind: SymbolKind.Expression,
tsType: this.getTypeChecker().getTypeAtLocation(node)
};
} else {
const symbolInfo = this.getSymbolOfTsNode(node);
return symbolInfo === null ? null : { ...symbolInfo, kind: SymbolKind.Expression };
}
}
getSymbolOfTsNode(node) {
var _a;
while (ts31.isParenthesizedExpression(node)) {
node = node.expression;
}
let tsSymbol;
if (ts31.isPropertyAccessExpression(node)) {
tsSymbol = this.getTypeChecker().getSymbolAtLocation(node.name);
} else {
tsSymbol = this.getTypeChecker().getSymbolAtLocation(node);
}
const positionInFile = this.getTcbPositionForNode(node);
const type = this.getTypeChecker().getTypeAtLocation(node);
return {
tsSymbol: (_a = tsSymbol != null ? tsSymbol : type.symbol) != null ? _a : null,
tsType: type,
tcbLocation: {
tcbPath: this.tcbPath,
isShimFile: this.tcbIsShim,
positionInFile
}
};
}
getTcbPositionForNode(node) {
if (ts31.isTypeReferenceNode(node)) {
return this.getTcbPositionForNode(node.typeName);
} else if (ts31.isQualifiedName(node)) {
return node.right.getStart();
} else if (ts31.isPropertyAccessExpression(node)) {
return node.name.getStart();
} else if (ts31.isElementAccessExpression(node)) {
return node.argumentExpression.getStart();
} else {
return node.getStart();
}
}
};
function anyNodeFilter(n) {
return true;
}
function sourceSpanEqual(a, b) {
return a.start.offset === b.start.offset && a.end.offset === b.end.offset;
}
function unwrapSignalInputWriteTAccessor(expr) {
if (!ts31.isElementAccessExpression(expr) || !ts31.isPropertyAccessExpression(expr.argumentExpression)) {
return null;
}
if (!ts31.isIdentifier(expr.argumentExpression.name) || expr.argumentExpression.name.text !== R3Identifiers4.InputSignalBrandWriteType.name) {
return null;
}
if (!ts31.isPropertyAccessExpression(expr.expression) && !ts31.isElementAccessExpression(expr.expression)) {
throw new Error("Unexpected expression for signal input write type.");
}
return {
fieldExpr: expr.expression,
typeExpr: expr
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/src/checker.mjs
var REGISTRY2 = new DomElementSchemaRegistry2();
var TemplateTypeCheckerImpl = class {
constructor(originalProgram, programDriver, typeCheckAdapter, config, refEmitter, reflector, compilerHost, priorBuild, metaReader, localMetaReader, ngModuleIndex, componentScopeReader, typeCheckScopeRegistry, perf) {
this.originalProgram = originalProgram;
this.programDriver = programDriver;
this.typeCheckAdapter = typeCheckAdapter;
this.config = config;
this.refEmitter = refEmitter;
this.reflector = reflector;
this.compilerHost = compilerHost;
this.priorBuild = priorBuild;
this.metaReader = metaReader;
this.localMetaReader = localMetaReader;
this.ngModuleIndex = ngModuleIndex;
this.componentScopeReader = componentScopeReader;
this.typeCheckScopeRegistry = typeCheckScopeRegistry;
this.perf = perf;
this.state = /* @__PURE__ */ new Map();
this.completionCache = /* @__PURE__ */ new Map();
this.symbolBuilderCache = /* @__PURE__ */ new Map();
this.scopeCache = /* @__PURE__ */ new Map();
this.elementTagCache = /* @__PURE__ */ new Map();
this.isComplete = false;
}
getTemplate(component) {
const { data } = this.getLatestComponentState(component);
if (data === null) {
return null;
}
return data.template;
}
getUsedDirectives(component) {
var _a;
return ((_a = this.getLatestComponentState(component).data) == null ? void 0 : _a.boundTarget.getUsedDirectives()) || null;
}
getUsedPipes(component) {
var _a;
return ((_a = this.getLatestComponentState(component).data) == null ? void 0 : _a.boundTarget.getUsedPipes()) || null;
}
getLatestComponentState(component) {
this.ensureShimForComponent(component);
const sf = component.getSourceFile();
const sfPath = absoluteFromSourceFile(sf);
const shimPath = TypeCheckShimGenerator.shimFor(sfPath);
const fileRecord = this.getFileData(sfPath);
if (!fileRecord.shimData.has(shimPath)) {
return { data: null, tcb: null, tcbPath: shimPath, tcbIsShim: true };
}
const templateId = fileRecord.sourceManager.getTemplateId(component);
const shimRecord = fileRecord.shimData.get(shimPath);
const id = fileRecord.sourceManager.getTemplateId(component);
const program = this.programDriver.getProgram();
const shimSf = getSourceFileOrNull(program, shimPath);
if (shimSf === null || !fileRecord.shimData.has(shimPath)) {
throw new Error(`Error: no shim file in program: ${shimPath}`);
}
let tcb = findTypeCheckBlock(shimSf, id, false);
let tcbPath = shimPath;
if (tcb === null) {
const inlineSf = getSourceFileOrError(program, sfPath);
tcb = findTypeCheckBlock(inlineSf, id, false);
if (tcb !== null) {
tcbPath = sfPath;
}
}
let data = null;
if (shimRecord.templates.has(templateId)) {
data = shimRecord.templates.get(templateId);
}
return { data, tcb, tcbPath, tcbIsShim: tcbPath === shimPath };
}
isTrackedTypeCheckFile(filePath) {
return this.getFileAndShimRecordsForPath(filePath) !== null;
}
getFileRecordForTcbLocation({ tcbPath, isShimFile }) {
if (!isShimFile) {
if (this.state.has(tcbPath)) {
return this.state.get(tcbPath);
} else {
return null;
}
}
const records = this.getFileAndShimRecordsForPath(tcbPath);
if (records !== null) {
return records.fileRecord;
} else {
return null;
}
}
getFileAndShimRecordsForPath(shimPath) {
for (const fileRecord of this.state.values()) {
if (fileRecord.shimData.has(shimPath)) {
return { fileRecord, shimRecord: fileRecord.shimData.get(shimPath) };
}
}
return null;
}
getTemplateMappingAtTcbLocation(tcbLocation) {
const fileRecord = this.getFileRecordForTcbLocation(tcbLocation);
if (fileRecord === null) {
return null;
}
const shimSf = this.programDriver.getProgram().getSourceFile(tcbLocation.tcbPath);
if (shimSf === void 0) {
return null;
}
return getTemplateMapping(
shimSf,
tcbLocation.positionInFile,
fileRecord.sourceManager,
false
);
}
generateAllTypeCheckBlocks() {
this.ensureAllShimsForAllFiles();
}
getDiagnosticsForFile(sf, optimizeFor) {
switch (optimizeFor) {
case OptimizeFor.WholeProgram:
this.ensureAllShimsForAllFiles();
break;
case OptimizeFor.SingleFile:
this.ensureAllShimsForOneFile(sf);
break;
}
return this.perf.inPhase(PerfPhase.TtcDiagnostics, () => {
const sfPath = absoluteFromSourceFile(sf);
const fileRecord = this.state.get(sfPath);
const typeCheckProgram = this.programDriver.getProgram();
const diagnostics = [];
if (fileRecord.hasInlines) {
const inlineSf = getSourceFileOrError(typeCheckProgram, sfPath);
diagnostics.push(...typeCheckProgram.getSemanticDiagnostics(inlineSf).map((diag) => convertDiagnostic(diag, fileRecord.sourceManager)));
}
for (const [shimPath, shimRecord] of fileRecord.shimData) {
const shimSf = getSourceFileOrError(typeCheckProgram, shimPath);
diagnostics.push(...typeCheckProgram.getSemanticDiagnostics(shimSf).map((diag) => convertDiagnostic(diag, fileRecord.sourceManager)));
diagnostics.push(...shimRecord.genesisDiagnostics);
for (const templateData of shimRecord.templates.values()) {
diagnostics.push(...templateData.templateDiagnostics);
}
}
return diagnostics.filter((diag) => diag !== null);
});
}
getDiagnosticsForComponent(component) {
this.ensureShimForComponent(component);
return this.perf.inPhase(PerfPhase.TtcDiagnostics, () => {
const sf = component.getSourceFile();
const sfPath = absoluteFromSourceFile(sf);
const shimPath = TypeCheckShimGenerator.shimFor(sfPath);
const fileRecord = this.getFileData(sfPath);
if (!fileRecord.shimData.has(shimPath)) {
return [];
}
const templateId = fileRecord.sourceManager.getTemplateId(component);
const shimRecord = fileRecord.shimData.get(shimPath);
const typeCheckProgram = this.programDriver.getProgram();
const diagnostics = [];
if (shimRecord.hasInlines) {
const inlineSf = getSourceFileOrError(typeCheckProgram, sfPath);
diagnostics.push(...typeCheckProgram.getSemanticDiagnostics(inlineSf).map((diag) => convertDiagnostic(diag, fileRecord.sourceManager)));
}
const shimSf = getSourceFileOrError(typeCheckProgram, shimPath);
diagnostics.push(...typeCheckProgram.getSemanticDiagnostics(shimSf).map((diag) => convertDiagnostic(diag, fileRecord.sourceManager)));
diagnostics.push(...shimRecord.genesisDiagnostics);
for (const templateData of shimRecord.templates.values()) {
diagnostics.push(...templateData.templateDiagnostics);
}
return diagnostics.filter((diag) => diag !== null && diag.templateId === templateId);
});
}
getTypeCheckBlock(component) {
return this.getLatestComponentState(component).tcb;
}
getGlobalCompletions(context, component, node) {
const engine = this.getOrCreateCompletionEngine(component);
if (engine === null) {
return null;
}
return this.perf.inPhase(PerfPhase.TtcAutocompletion, () => engine.getGlobalCompletions(context, node));
}
getExpressionCompletionLocation(ast, component) {
const engine = this.getOrCreateCompletionEngine(component);
if (engine === null) {
return null;
}
return this.perf.inPhase(PerfPhase.TtcAutocompletion, () => engine.getExpressionCompletionLocation(ast));
}
getLiteralCompletionLocation(node, component) {
const engine = this.getOrCreateCompletionEngine(component);
if (engine === null) {
return null;
}
return this.perf.inPhase(PerfPhase.TtcAutocompletion, () => engine.getLiteralCompletionLocation(node));
}
invalidateClass(clazz) {
this.completionCache.delete(clazz);
this.symbolBuilderCache.delete(clazz);
this.scopeCache.delete(clazz);
this.elementTagCache.delete(clazz);
const sf = clazz.getSourceFile();
const sfPath = absoluteFromSourceFile(sf);
const shimPath = TypeCheckShimGenerator.shimFor(sfPath);
const fileData = this.getFileData(sfPath);
const templateId = fileData.sourceManager.getTemplateId(clazz);
fileData.shimData.delete(shimPath);
fileData.isComplete = false;
this.isComplete = false;
}
makeTemplateDiagnostic(clazz, sourceSpan, category, errorCode, message, relatedInformation) {
const sfPath = absoluteFromSourceFile(clazz.getSourceFile());
const fileRecord = this.state.get(sfPath);
const templateId = fileRecord.sourceManager.getTemplateId(clazz);
const mapping = fileRecord.sourceManager.getSourceMapping(templateId);
return {
...makeTemplateDiagnostic(templateId, mapping, sourceSpan, category, ngErrorCode(errorCode), message, relatedInformation),
__ngCode: errorCode
};
}
getOrCreateCompletionEngine(component) {
if (this.completionCache.has(component)) {
return this.completionCache.get(component);
}
const { tcb, data, tcbPath, tcbIsShim } = this.getLatestComponentState(component);
if (tcb === null || data === null) {
return null;
}
const engine = new CompletionEngine(tcb, data, tcbPath, tcbIsShim);
this.completionCache.set(component, engine);
return engine;
}
maybeAdoptPriorResultsForFile(sf) {
const sfPath = absoluteFromSourceFile(sf);
if (this.state.has(sfPath)) {
const existingResults = this.state.get(sfPath);
if (existingResults.isComplete) {
return;
}
}
const previousResults = this.priorBuild.priorTypeCheckingResultsFor(sf);
if (previousResults === null || !previousResults.isComplete) {
return;
}
this.perf.eventCount(PerfEvent.ReuseTypeCheckFile);
this.state.set(sfPath, previousResults);
}
ensureAllShimsForAllFiles() {
if (this.isComplete) {
return;
}
this.perf.inPhase(PerfPhase.TcbGeneration, () => {
const host = new WholeProgramTypeCheckingHost(this);
const ctx = this.newContext(host);
for (const sf of this.originalProgram.getSourceFiles()) {
if (sf.isDeclarationFile || isShim(sf)) {
continue;
}
this.maybeAdoptPriorResultsForFile(sf);
const sfPath = absoluteFromSourceFile(sf);
const fileData = this.getFileData(sfPath);
if (fileData.isComplete) {
continue;
}
this.typeCheckAdapter.typeCheck(sf, ctx);
fileData.isComplete = true;
}
this.updateFromContext(ctx);
this.isComplete = true;
});
}
ensureAllShimsForOneFile(sf) {
this.perf.inPhase(PerfPhase.TcbGeneration, () => {
this.maybeAdoptPriorResultsForFile(sf);
const sfPath = absoluteFromSourceFile(sf);
const fileData = this.getFileData(sfPath);
if (fileData.isComplete) {
return;
}
const host = new SingleFileTypeCheckingHost(sfPath, fileData, this);
const ctx = this.newContext(host);
this.typeCheckAdapter.typeCheck(sf, ctx);
fileData.isComplete = true;
this.updateFromContext(ctx);
});
}
ensureShimForComponent(component) {
const sf = component.getSourceFile();
const sfPath = absoluteFromSourceFile(sf);
const shimPath = TypeCheckShimGenerator.shimFor(sfPath);
this.maybeAdoptPriorResultsForFile(sf);
const fileData = this.getFileData(sfPath);
if (fileData.shimData.has(shimPath)) {
return;
}
const host = new SingleShimTypeCheckingHost(sfPath, fileData, this, shimPath);
const ctx = this.newContext(host);
this.typeCheckAdapter.typeCheck(sf, ctx);
this.updateFromContext(ctx);
}
newContext(host) {
const inlining = this.programDriver.supportsInlineOperations ? InliningMode.InlineOps : InliningMode.Error;
return new TypeCheckContextImpl(this.config, this.compilerHost, this.refEmitter, this.reflector, host, inlining, this.perf);
}
clearAllShimDataUsingInlines() {
for (const fileData of this.state.values()) {
if (!fileData.hasInlines) {
continue;
}
for (const [shimFile, shimData] of fileData.shimData.entries()) {
if (shimData.hasInlines) {
fileData.shimData.delete(shimFile);
}
}
fileData.hasInlines = false;
fileData.isComplete = false;
this.isComplete = false;
}
}
updateFromContext(ctx) {
const updates = ctx.finalize();
return this.perf.inPhase(PerfPhase.TcbUpdateProgram, () => {
if (updates.size > 0) {
this.perf.eventCount(PerfEvent.UpdateTypeCheckProgram);
}
this.programDriver.updateFiles(updates, UpdateMode.Incremental);
this.priorBuild.recordSuccessfulTypeCheck(this.state);
this.perf.memory(PerfCheckpoint.TtcUpdateProgram);
});
}
getFileData(path2) {
if (!this.state.has(path2)) {
this.state.set(path2, {
hasInlines: false,
sourceManager: new TemplateSourceManager(),
isComplete: false,
shimData: /* @__PURE__ */ new Map()
});
}
return this.state.get(path2);
}
getSymbolOfNode(node, component) {
const builder = this.getOrCreateSymbolBuilder(component);
if (builder === null) {
return null;
}
return this.perf.inPhase(PerfPhase.TtcSymbol, () => builder.getSymbol(node));
}
getOrCreateSymbolBuilder(component) {
if (this.symbolBuilderCache.has(component)) {
return this.symbolBuilderCache.get(component);
}
const { tcb, data, tcbPath, tcbIsShim } = this.getLatestComponentState(component);
if (tcb === null || data === null) {
return null;
}
const builder = new SymbolBuilder(tcbPath, tcbIsShim, tcb, data, this.componentScopeReader, () => this.programDriver.getProgram().getTypeChecker());
this.symbolBuilderCache.set(component, builder);
return builder;
}
getPotentialTemplateDirectives(component) {
var _a, _b;
const typeChecker = this.programDriver.getProgram().getTypeChecker();
const inScopeDirectives = (_b = (_a = this.getScopeData(component)) == null ? void 0 : _a.directives) != null ? _b : [];
const resultingDirectives = /* @__PURE__ */ new Map();
for (const d of inScopeDirectives) {
resultingDirectives.set(d.ref.node, d);
}
for (const directiveClass of this.localMetaReader.getKnown(MetaKind.Directive)) {
const directiveMeta = this.metaReader.getDirectiveMetadata(new Reference(directiveClass));
if (directiveMeta === null)
continue;
if (resultingDirectives.has(directiveClass))
continue;
const withScope = this.scopeDataOfDirectiveMeta(typeChecker, directiveMeta);
if (withScope === null)
continue;
resultingDirectives.set(directiveClass, { ...withScope, isInScope: false });
}
return Array.from(resultingDirectives.values());
}
getPotentialPipes(component) {
var _a, _b;
const typeChecker = this.programDriver.getProgram().getTypeChecker();
const inScopePipes = (_b = (_a = this.getScopeData(component)) == null ? void 0 : _a.pipes) != null ? _b : [];
const resultingPipes = /* @__PURE__ */ new Map();
for (const p of inScopePipes) {
resultingPipes.set(p.ref.node, p);
}
for (const pipeClass of this.localMetaReader.getKnown(MetaKind.Pipe)) {
const pipeMeta = this.metaReader.getPipeMetadata(new Reference(pipeClass));
if (pipeMeta === null)
continue;
if (resultingPipes.has(pipeClass))
continue;
const withScope = this.scopeDataOfPipeMeta(typeChecker, pipeMeta);
if (withScope === null)
continue;
resultingPipes.set(pipeClass, { ...withScope, isInScope: false });
}
return Array.from(resultingPipes.values());
}
getDirectiveMetadata(dir) {
if (!isNamedClassDeclaration(dir)) {
return null;
}
return this.typeCheckScopeRegistry.getTypeCheckDirectiveMetadata(new Reference(dir));
}
getNgModuleMetadata(module) {
if (!isNamedClassDeclaration(module)) {
return null;
}
return this.metaReader.getNgModuleMetadata(new Reference(module));
}
getPipeMetadata(pipe) {
if (!isNamedClassDeclaration(pipe)) {
return null;
}
return this.metaReader.getPipeMetadata(new Reference(pipe));
}
getPotentialElementTags(component) {
if (this.elementTagCache.has(component)) {
return this.elementTagCache.get(component);
}
const tagMap = /* @__PURE__ */ new Map();
for (const tag of REGISTRY2.allKnownElementNames()) {
tagMap.set(tag, null);
}
const scope = this.getScopeData(component);
if (scope !== null) {
for (const directive of scope.directives) {
if (directive.selector === null) {
continue;
}
for (const selector of CssSelector2.parse(directive.selector)) {
if (selector.element === null || tagMap.has(selector.element)) {
continue;
}
tagMap.set(selector.element, directive);
}
}
}
this.elementTagCache.set(component, tagMap);
return tagMap;
}
getPotentialDomBindings(tagName) {
const attributes = REGISTRY2.allKnownAttributesOfElement(tagName);
return attributes.map((attribute) => ({
attribute,
property: REGISTRY2.getMappedPropName(attribute)
}));
}
getPotentialDomEvents(tagName) {
return REGISTRY2.allKnownEventsOfElement(tagName);
}
getPrimaryAngularDecorator(target) {
this.ensureAllShimsForOneFile(target.getSourceFile());
if (!isNamedClassDeclaration(target)) {
return null;
}
const ref = new Reference(target);
const dirMeta = this.metaReader.getDirectiveMetadata(ref);
if (dirMeta !== null) {
return dirMeta.decorator;
}
const pipeMeta = this.metaReader.getPipeMetadata(ref);
if (pipeMeta !== null) {
return pipeMeta.decorator;
}
const ngModuleMeta = this.metaReader.getNgModuleMetadata(ref);
if (ngModuleMeta !== null) {
return ngModuleMeta.decorator;
}
return null;
}
getOwningNgModule(component) {
if (!isNamedClassDeclaration(component)) {
return null;
}
const dirMeta = this.metaReader.getDirectiveMetadata(new Reference(component));
if (dirMeta !== null && dirMeta.isStandalone) {
return null;
}
const scope = this.componentScopeReader.getScopeForComponent(component);
if (scope === null || scope.kind !== ComponentScopeKind.NgModule || !isNamedClassDeclaration(scope.ngModule)) {
return null;
}
return scope.ngModule;
}
emit(kind, refTo, inContext) {
var _a, _b;
const emittedRef = this.refEmitter.emit(refTo, inContext.getSourceFile());
if (emittedRef.kind === 1) {
return null;
}
const emitted = emittedRef.expression;
if (emitted instanceof WrappedNodeExpr2) {
if (refTo.node === inContext) {
return null;
}
let isForwardReference = false;
if (emitted.node.getStart() > inContext.getStart()) {
const declaration = (_b = (_a = this.programDriver.getProgram().getTypeChecker().getTypeAtLocation(emitted.node).getSymbol()) == null ? void 0 : _a.declarations) == null ? void 0 : _b[0];
if (declaration && declaration.getSourceFile() === inContext.getSourceFile()) {
isForwardReference = true;
}
}
return { kind, symbolName: emitted.node.text, isForwardReference };
} else if (emitted instanceof ExternalExpr2 && emitted.value.moduleName !== null && emitted.value.name !== null) {
return {
kind,
moduleSpecifier: emitted.value.moduleName,
symbolName: emitted.value.name,
isForwardReference: false
};
}
return null;
}
getPotentialImportsFor(toImport, inContext, importMode) {
var _a;
const imports = [];
const meta = (_a = this.metaReader.getDirectiveMetadata(toImport)) != null ? _a : this.metaReader.getPipeMetadata(toImport);
if (meta === null) {
return imports;
}
if (meta.isStandalone || importMode === PotentialImportMode.ForceDirect) {
const emitted = this.emit(PotentialImportKind.Standalone, toImport, inContext);
if (emitted !== null) {
imports.push(emitted);
}
}
const exportingNgModules = this.ngModuleIndex.getNgModulesExporting(meta.ref.node);
if (exportingNgModules !== null) {
for (const exporter of exportingNgModules) {
const emittedRef = this.emit(PotentialImportKind.NgModule, exporter, inContext);
if (emittedRef !== null) {
imports.push(emittedRef);
}
}
}
return imports;
}
getScopeData(component) {
if (this.scopeCache.has(component)) {
return this.scopeCache.get(component);
}
if (!isNamedClassDeclaration(component)) {
throw new Error(`AssertionError: components must have names`);
}
const scope = this.componentScopeReader.getScopeForComponent(component);
if (scope === null) {
return null;
}
const dependencies = scope.kind === ComponentScopeKind.NgModule ? scope.compilation.dependencies : scope.dependencies;
const data = {
directives: [],
pipes: [],
isPoisoned: scope.kind === ComponentScopeKind.NgModule ? scope.compilation.isPoisoned : scope.isPoisoned
};
const typeChecker = this.programDriver.getProgram().getTypeChecker();
for (const dep of dependencies) {
if (dep.kind === MetaKind.Directive) {
const dirScope = this.scopeDataOfDirectiveMeta(typeChecker, dep);
if (dirScope === null)
continue;
data.directives.push({ ...dirScope, isInScope: true });
} else if (dep.kind === MetaKind.Pipe) {
const pipeScope = this.scopeDataOfPipeMeta(typeChecker, dep);
if (pipeScope === null)
continue;
data.pipes.push({ ...pipeScope, isInScope: true });
}
}
this.scopeCache.set(component, data);
return data;
}
scopeDataOfDirectiveMeta(typeChecker, dep) {
if (dep.selector === null) {
return null;
}
const tsSymbol = typeChecker.getSymbolAtLocation(dep.ref.node.name);
if (!isSymbolWithValueDeclaration(tsSymbol)) {
return null;
}
let ngModule = null;
const moduleScopeOfDir = this.componentScopeReader.getScopeForComponent(dep.ref.node);
if (moduleScopeOfDir !== null && moduleScopeOfDir.kind === ComponentScopeKind.NgModule) {
ngModule = moduleScopeOfDir.ngModule;
}
return {
ref: dep.ref,
isComponent: dep.isComponent,
isStructural: dep.isStructural,
selector: dep.selector,
tsSymbol,
ngModule
};
}
scopeDataOfPipeMeta(typeChecker, dep) {
const tsSymbol = typeChecker.getSymbolAtLocation(dep.ref.node.name);
if (tsSymbol === void 0) {
return null;
}
return {
ref: dep.ref,
name: dep.name,
tsSymbol
};
}
};
function convertDiagnostic(diag, sourceResolver) {
if (!shouldReportDiagnostic(diag)) {
return null;
}
return translateDiagnostic(diag, sourceResolver);
}
var WholeProgramTypeCheckingHost = class {
constructor(impl) {
this.impl = impl;
}
getSourceManager(sfPath) {
return this.impl.getFileData(sfPath).sourceManager;
}
shouldCheckComponent(node) {
const sfPath = absoluteFromSourceFile(node.getSourceFile());
const shimPath = TypeCheckShimGenerator.shimFor(sfPath);
const fileData = this.impl.getFileData(sfPath);
return !fileData.shimData.has(shimPath);
}
recordShimData(sfPath, data) {
const fileData = this.impl.getFileData(sfPath);
fileData.shimData.set(data.path, data);
if (data.hasInlines) {
fileData.hasInlines = true;
}
}
recordComplete(sfPath) {
this.impl.getFileData(sfPath).isComplete = true;
}
};
var SingleFileTypeCheckingHost = class {
constructor(sfPath, fileData, impl) {
this.sfPath = sfPath;
this.fileData = fileData;
this.impl = impl;
this.seenInlines = false;
}
assertPath(sfPath) {
if (this.sfPath !== sfPath) {
throw new Error(`AssertionError: querying TypeCheckingHost outside of assigned file`);
}
}
getSourceManager(sfPath) {
this.assertPath(sfPath);
return this.fileData.sourceManager;
}
shouldCheckComponent(node) {
if (this.sfPath !== absoluteFromSourceFile(node.getSourceFile())) {
return false;
}
const shimPath = TypeCheckShimGenerator.shimFor(this.sfPath);
return !this.fileData.shimData.has(shimPath);
}
recordShimData(sfPath, data) {
this.assertPath(sfPath);
if (data.hasInlines && !this.seenInlines) {
this.impl.clearAllShimDataUsingInlines();
this.seenInlines = true;
}
this.fileData.shimData.set(data.path, data);
if (data.hasInlines) {
this.fileData.hasInlines = true;
}
}
recordComplete(sfPath) {
this.assertPath(sfPath);
this.fileData.isComplete = true;
}
};
var SingleShimTypeCheckingHost = class extends SingleFileTypeCheckingHost {
constructor(sfPath, fileData, impl, shimPath) {
super(sfPath, fileData, impl);
this.shimPath = shimPath;
}
shouldCheckNode(node) {
if (this.sfPath !== absoluteFromSourceFile(node.getSourceFile())) {
return false;
}
const shimPath = TypeCheckShimGenerator.shimFor(this.sfPath);
if (shimPath !== this.shimPath) {
return false;
}
return !this.fileData.shimData.has(shimPath);
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/interpolated_signal_not_invoked/index.mjs
import { Interpolation, PropertyRead as PropertyRead6 } from "@angular/compiler";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/api/api.mjs
import { ASTWithSource as ASTWithSource4, RecursiveAstVisitor as RecursiveAstVisitor3, TmplAstBoundDeferredTrigger as TmplAstBoundDeferredTrigger2 } from "@angular/compiler";
var TemplateCheckWithVisitor = class {
run(ctx, component, template) {
const visitor = new TemplateVisitor2(ctx, component, this);
return visitor.getDiagnostics(template);
}
};
var TemplateVisitor2 = class extends RecursiveAstVisitor3 {
constructor(ctx, component, check) {
super();
this.ctx = ctx;
this.component = component;
this.check = check;
this.diagnostics = [];
}
visit(node, context) {
this.diagnostics.push(...this.check.visitNode(this.ctx, this.component, node));
node.visit(this);
}
visitAllNodes(nodes) {
for (const node of nodes) {
this.visit(node);
}
}
visitAst(ast) {
if (ast instanceof ASTWithSource4) {
ast = ast.ast;
}
this.visit(ast);
}
visitElement(element) {
this.visitAllNodes(element.attributes);
this.visitAllNodes(element.inputs);
this.visitAllNodes(element.outputs);
this.visitAllNodes(element.references);
this.visitAllNodes(element.children);
}
visitTemplate(template) {
this.visitAllNodes(template.attributes);
if (template.tagName === "ng-template") {
this.visitAllNodes(template.inputs);
this.visitAllNodes(template.outputs);
this.visitAllNodes(template.templateAttrs);
}
this.visitAllNodes(template.variables);
this.visitAllNodes(template.references);
this.visitAllNodes(template.children);
}
visitContent(content) {
}
visitVariable(variable) {
}
visitReference(reference) {
}
visitTextAttribute(attribute) {
}
visitUnknownBlock(block) {
}
visitBoundAttribute(attribute) {
this.visitAst(attribute.value);
}
visitBoundEvent(attribute) {
this.visitAst(attribute.handler);
}
visitText(text) {
}
visitBoundText(text) {
this.visitAst(text.value);
}
visitIcu(icu) {
}
visitDeferredBlock(deferred) {
deferred.visitAll(this);
}
visitDeferredTrigger(trigger) {
if (trigger instanceof TmplAstBoundDeferredTrigger2) {
this.visitAst(trigger.value);
}
}
visitDeferredBlockPlaceholder(block) {
this.visitAllNodes(block.children);
}
visitDeferredBlockError(block) {
this.visitAllNodes(block.children);
}
visitDeferredBlockLoading(block) {
this.visitAllNodes(block.children);
}
visitSwitchBlock(block) {
this.visitAst(block.expression);
this.visitAllNodes(block.cases);
}
visitSwitchBlockCase(block) {
block.expression && this.visitAst(block.expression);
this.visitAllNodes(block.children);
}
visitForLoopBlock(block) {
var _a;
block.item.visit(this);
this.visitAllNodes(Object.values(block.contextVariables));
this.visitAst(block.expression);
this.visitAllNodes(block.children);
(_a = block.empty) == null ? void 0 : _a.visit(this);
}
visitForLoopBlockEmpty(block) {
this.visitAllNodes(block.children);
}
visitIfBlock(block) {
this.visitAllNodes(block.branches);
}
visitIfBlockBranch(block) {
var _a;
block.expression && this.visitAst(block.expression);
(_a = block.expressionAlias) == null ? void 0 : _a.visit(this);
this.visitAllNodes(block.children);
}
getDiagnostics(template) {
this.diagnostics = [];
this.visitAllNodes(template);
return this.diagnostics;
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/interpolated_signal_not_invoked/index.mjs
var InterpolatedSignalCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.INTERPOLATED_SIGNAL_NOT_INVOKED;
}
visitNode(ctx, component, node) {
if (node instanceof Interpolation) {
return node.expressions.filter((item) => item instanceof PropertyRead6).flatMap((item) => {
if (item instanceof PropertyRead6) {
return buildDiagnosticForSignal(ctx, item, component);
}
return [];
});
}
return [];
}
};
function isSignal(symbol) {
return ((symbol == null ? void 0 : symbol.escapedName) === "WritableSignal" || (symbol == null ? void 0 : symbol.escapedName) === "Signal" || (symbol == null ? void 0 : symbol.escapedName) === "InputSignal" || (symbol == null ? void 0 : symbol.escapedName) === "InputSignalWithTransform") && symbol.parent.escapedName.includes("@angular/core");
}
function buildDiagnosticForSignal(ctx, node, component) {
const symbol = ctx.templateTypeChecker.getSymbolOfNode(node, component);
if ((symbol == null ? void 0 : symbol.kind) === SymbolKind.Expression && (isSignal(symbol.tsType.symbol) || isSignal(symbol.tsType.aliasSymbol))) {
const templateMapping = ctx.templateTypeChecker.getTemplateMappingAtTcbLocation(symbol.tcbLocation);
const errorString = `${node.name} is a function and should be invoked: ${node.name}()`;
const diagnostic = ctx.makeTemplateDiagnostic(templateMapping.span, errorString);
return [diagnostic];
}
return [];
}
var factory = {
code: ErrorCode.INTERPOLATED_SIGNAL_NOT_INVOKED,
name: ExtendedTemplateDiagnosticName.INTERPOLATED_SIGNAL_NOT_INVOKED,
create: () => new InterpolatedSignalCheck()
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/invalid_banana_in_box/index.mjs
import { TmplAstBoundEvent as TmplAstBoundEvent2 } from "@angular/compiler";
var InvalidBananaInBoxCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.INVALID_BANANA_IN_BOX;
}
visitNode(ctx, component, node) {
if (!(node instanceof TmplAstBoundEvent2))
return [];
const name = node.name;
if (!name.startsWith("[") || !name.endsWith("]"))
return [];
const boundSyntax = node.sourceSpan.toString();
const expectedBoundSyntax = boundSyntax.replace(`(${name})`, `[(${name.slice(1, -1)})]`);
const diagnostic = ctx.makeTemplateDiagnostic(node.sourceSpan, `In the two-way binding syntax the parentheses should be inside the brackets, ex. '${expectedBoundSyntax}'.
Find more at https://angular.io/guide/two-way-binding`);
return [diagnostic];
}
};
var factory2 = {
code: ErrorCode.INVALID_BANANA_IN_BOX,
name: ExtendedTemplateDiagnosticName.INVALID_BANANA_IN_BOX,
create: () => new InvalidBananaInBoxCheck()
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/missing_control_flow_directive/index.mjs
import { TmplAstTemplate as TmplAstTemplate4 } from "@angular/compiler";
var KNOWN_CONTROL_FLOW_DIRECTIVES = /* @__PURE__ */ new Map([
["ngIf", { directive: "NgIf", builtIn: "@if" }],
["ngFor", { directive: "NgFor", builtIn: "@for" }],
["ngSwitchCase", { directive: "NgSwitchCase", builtIn: "@switch with @case" }],
["ngSwitchDefault", { directive: "NgSwitchDefault", builtIn: "@switch with @default" }]
]);
var MissingControlFlowDirectiveCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.MISSING_CONTROL_FLOW_DIRECTIVE;
}
run(ctx, component, template) {
const componentMetadata = ctx.templateTypeChecker.getDirectiveMetadata(component);
if (!componentMetadata || !componentMetadata.isStandalone) {
return [];
}
return super.run(ctx, component, template);
}
visitNode(ctx, component, node) {
if (!(node instanceof TmplAstTemplate4))
return [];
const controlFlowAttr = node.templateAttrs.find((attr) => KNOWN_CONTROL_FLOW_DIRECTIVES.has(attr.name));
if (!controlFlowAttr)
return [];
const symbol = ctx.templateTypeChecker.getSymbolOfNode(node, component);
if (symbol === null || symbol.directives.length > 0) {
return [];
}
const sourceSpan = controlFlowAttr.keySpan || controlFlowAttr.sourceSpan;
const directiveAndBuiltIn = KNOWN_CONTROL_FLOW_DIRECTIVES.get(controlFlowAttr.name);
const errorMessage = `The \`*${controlFlowAttr.name}\` directive was used in the template, but neither the \`${directiveAndBuiltIn == null ? void 0 : directiveAndBuiltIn.directive}\` directive nor the \`CommonModule\` was imported. Use Angular's built-in control flow ${directiveAndBuiltIn == null ? void 0 : directiveAndBuiltIn.builtIn} or make sure that either the \`${directiveAndBuiltIn == null ? void 0 : directiveAndBuiltIn.directive}\` directive or the \`CommonModule\` is included in the \`@Component.imports\` array of this component.`;
const diagnostic = ctx.makeTemplateDiagnostic(sourceSpan, errorMessage);
return [diagnostic];
}
};
var factory3 = {
code: ErrorCode.MISSING_CONTROL_FLOW_DIRECTIVE,
name: ExtendedTemplateDiagnosticName.MISSING_CONTROL_FLOW_DIRECTIVE,
create: (options) => {
return new MissingControlFlowDirectiveCheck();
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/missing_ngforof_let/index.mjs
import { TmplAstTemplate as TmplAstTemplate5 } from "@angular/compiler";
var MissingNgForOfLetCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.MISSING_NGFOROF_LET;
}
visitNode(ctx, component, node) {
const isTemplate = node instanceof TmplAstTemplate5;
if (!(node instanceof TmplAstTemplate5)) {
return [];
}
if (node.templateAttrs.length === 0) {
return [];
}
const attr = node.templateAttrs.find((x) => x.name === "ngFor");
if (attr === void 0) {
return [];
}
if (node.variables.length > 0) {
return [];
}
const errorString = "Your ngFor is missing a value. Did you forget to add the `let` keyword?";
const diagnostic = ctx.makeTemplateDiagnostic(attr.sourceSpan, errorString);
return [diagnostic];
}
};
var factory4 = {
code: ErrorCode.MISSING_NGFOROF_LET,
name: ExtendedTemplateDiagnosticName.MISSING_NGFOROF_LET,
create: () => new MissingNgForOfLetCheck()
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/nullish_coalescing_not_nullable/index.mjs
import { Binary } from "@angular/compiler";
import ts32 from "typescript";
var NullishCoalescingNotNullableCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.NULLISH_COALESCING_NOT_NULLABLE;
}
visitNode(ctx, component, node) {
if (!(node instanceof Binary) || node.operation !== "??")
return [];
const symbolLeft = ctx.templateTypeChecker.getSymbolOfNode(node.left, component);
if (symbolLeft === null || symbolLeft.kind !== SymbolKind.Expression) {
return [];
}
const typeLeft = symbolLeft.tsType;
if (typeLeft.flags & (ts32.TypeFlags.Any | ts32.TypeFlags.Unknown)) {
return [];
}
if (typeLeft.getNonNullableType() !== typeLeft)
return [];
const symbol = ctx.templateTypeChecker.getSymbolOfNode(node, component);
if (symbol.kind !== SymbolKind.Expression) {
return [];
}
const templateMapping = ctx.templateTypeChecker.getTemplateMappingAtTcbLocation(symbol.tcbLocation);
if (templateMapping === null) {
return [];
}
const diagnostic = ctx.makeTemplateDiagnostic(templateMapping.span, `The left side of this nullish coalescing operation does not include 'null' or 'undefined' in its type, therefore the '??' operator can be safely removed.`);
return [diagnostic];
}
};
var factory5 = {
code: ErrorCode.NULLISH_COALESCING_NOT_NULLABLE,
name: ExtendedTemplateDiagnosticName.NULLISH_COALESCING_NOT_NULLABLE,
create: (options) => {
const strictNullChecks = options.strictNullChecks === void 0 ? !!options.strict : !!options.strictNullChecks;
if (!strictNullChecks) {
return null;
}
return new NullishCoalescingNotNullableCheck();
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/optional_chain_not_nullable/index.mjs
import { SafeCall as SafeCall2, SafeKeyedRead as SafeKeyedRead2, SafePropertyRead as SafePropertyRead5 } from "@angular/compiler";
import ts33 from "typescript";
var OptionalChainNotNullableCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.OPTIONAL_CHAIN_NOT_NULLABLE;
}
visitNode(ctx, component, node) {
if (!(node instanceof SafeCall2) && !(node instanceof SafePropertyRead5) && !(node instanceof SafeKeyedRead2))
return [];
const symbolLeft = ctx.templateTypeChecker.getSymbolOfNode(node.receiver, component);
if (symbolLeft === null || symbolLeft.kind !== SymbolKind.Expression) {
return [];
}
const typeLeft = symbolLeft.tsType;
if (typeLeft.flags & (ts33.TypeFlags.Any | ts33.TypeFlags.Unknown)) {
return [];
}
if (typeLeft.getNonNullableType() !== typeLeft)
return [];
const symbol = ctx.templateTypeChecker.getSymbolOfNode(node, component);
if (symbol.kind !== SymbolKind.Expression) {
return [];
}
const templateMapping = ctx.templateTypeChecker.getTemplateMappingAtTcbLocation(symbol.tcbLocation);
if (templateMapping === null) {
return [];
}
const advice = node instanceof SafePropertyRead5 ? `the '?.' operator can be replaced with the '.' operator` : `the '?.' operator can be safely removed`;
const diagnostic = ctx.makeTemplateDiagnostic(templateMapping.span, `The left side of this optional chain operation does not include 'null' or 'undefined' in its type, therefore ${advice}.`);
return [diagnostic];
}
};
var factory6 = {
code: ErrorCode.OPTIONAL_CHAIN_NOT_NULLABLE,
name: ExtendedTemplateDiagnosticName.OPTIONAL_CHAIN_NOT_NULLABLE,
create: (options) => {
const strictNullChecks = options.strictNullChecks === void 0 ? !!options.strict : !!options.strictNullChecks;
if (!strictNullChecks) {
return null;
}
return new OptionalChainNotNullableCheck();
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/suffix_not_supported/index.mjs
import { TmplAstBoundAttribute as TmplAstBoundAttribute3 } from "@angular/compiler";
var STYLE_SUFFIXES = ["px", "%", "em"];
var SuffixNotSupportedCheck = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.SUFFIX_NOT_SUPPORTED;
}
visitNode(ctx, component, node) {
if (!(node instanceof TmplAstBoundAttribute3))
return [];
if (!node.keySpan.toString().startsWith("attr.") || !STYLE_SUFFIXES.some((suffix) => node.name.endsWith(`.${suffix}`))) {
return [];
}
const diagnostic = ctx.makeTemplateDiagnostic(node.keySpan, `The ${STYLE_SUFFIXES.map((suffix) => `'.${suffix}'`).join(", ")} suffixes are only supported on style bindings.`);
return [diagnostic];
}
};
var factory7 = {
code: ErrorCode.SUFFIX_NOT_SUPPORTED,
name: ExtendedTemplateDiagnosticName.SUFFIX_NOT_SUPPORTED,
create: () => new SuffixNotSupportedCheck()
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/checks/text_attribute_not_binding/index.mjs
import { TmplAstTextAttribute as TmplAstTextAttribute4 } from "@angular/compiler";
var TextAttributeNotBindingSpec = class extends TemplateCheckWithVisitor {
constructor() {
super(...arguments);
this.code = ErrorCode.TEXT_ATTRIBUTE_NOT_BINDING;
}
visitNode(ctx, component, node) {
if (!(node instanceof TmplAstTextAttribute4))
return [];
const name = node.name;
if (!name.startsWith("attr.") && !name.startsWith("style.") && !name.startsWith("class.")) {
return [];
}
let errorString;
if (name.startsWith("attr.")) {
const staticAttr = name.replace("attr.", "");
errorString = `Static attributes should be written without the 'attr.' prefix.`;
if (node.value) {
errorString += ` For example, ${staticAttr}="${node.value}".`;
}
} else {
const expectedKey = `[${name}]`;
const expectedValue = node.value === "true" || node.value === "false" ? node.value : `'${node.value}'`;
errorString = "Attribute, style, and class bindings should be enclosed with square braces.";
if (node.value) {
errorString += ` For example, '${expectedKey}="${expectedValue}"'.`;
}
}
const diagnostic = ctx.makeTemplateDiagnostic(node.sourceSpan, errorString);
return [diagnostic];
}
};
var factory8 = {
code: ErrorCode.TEXT_ATTRIBUTE_NOT_BINDING,
name: ExtendedTemplateDiagnosticName.TEXT_ATTRIBUTE_NOT_BINDING,
create: () => new TextAttributeNotBindingSpec()
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/src/extended_template_checker.mjs
import ts34 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/core/api/src/public_options.mjs
var DiagnosticCategoryLabel;
(function(DiagnosticCategoryLabel2) {
DiagnosticCategoryLabel2["Warning"] = "warning";
DiagnosticCategoryLabel2["Error"] = "error";
DiagnosticCategoryLabel2["Suppress"] = "suppress";
})(DiagnosticCategoryLabel || (DiagnosticCategoryLabel = {}));
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/src/extended_template_checker.mjs
var ExtendedTemplateCheckerImpl = class {
constructor(templateTypeChecker, typeChecker, templateCheckFactories, options) {
var _a, _b, _c, _d, _e;
this.partialCtx = { templateTypeChecker, typeChecker };
this.templateChecks = /* @__PURE__ */ new Map();
for (const factory9 of templateCheckFactories) {
const category = diagnosticLabelToCategory((_e = (_d = (_b = (_a = options == null ? void 0 : options.extendedDiagnostics) == null ? void 0 : _a.checks) == null ? void 0 : _b[factory9.name]) != null ? _d : (_c = options == null ? void 0 : options.extendedDiagnostics) == null ? void 0 : _c.defaultCategory) != null ? _e : DiagnosticCategoryLabel.Warning);
if (category === null) {
continue;
}
const check = factory9.create(options);
if (check === null) {
continue;
}
this.templateChecks.set(check, category);
}
}
getDiagnosticsForComponent(component) {
const template = this.partialCtx.templateTypeChecker.getTemplate(component);
if (template === null) {
return [];
}
const diagnostics = [];
for (const [check, category] of this.templateChecks.entries()) {
const ctx = {
...this.partialCtx,
makeTemplateDiagnostic: (span, message, relatedInformation) => {
return this.partialCtx.templateTypeChecker.makeTemplateDiagnostic(component, span, category, check.code, message, relatedInformation);
}
};
diagnostics.push(...check.run(ctx, component, template));
}
return diagnostics;
}
};
function diagnosticLabelToCategory(label) {
switch (label) {
case DiagnosticCategoryLabel.Warning:
return ts34.DiagnosticCategory.Warning;
case DiagnosticCategoryLabel.Error:
return ts34.DiagnosticCategory.Error;
case DiagnosticCategoryLabel.Suppress:
return null;
default:
return assertNever(label);
}
}
function assertNever(value) {
throw new Error(`Unexpected call to 'assertNever()' with value:
${value}`);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/typecheck/extended/index.mjs
var ALL_DIAGNOSTIC_FACTORIES = [
factory2,
factory5,
factory6,
factory3,
factory8,
factory4,
factory7,
factory
];
var SUPPORTED_DIAGNOSTIC_NAMES = /* @__PURE__ */ new Set([
ExtendedTemplateDiagnosticName.CONTROL_FLOW_PREVENTING_CONTENT_PROJECTION,
...ALL_DIAGNOSTIC_FACTORIES.map((factory9) => factory9.name)
]);
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/core/src/compiler.mjs
var CompilationTicketKind;
(function(CompilationTicketKind2) {
CompilationTicketKind2[CompilationTicketKind2["Fresh"] = 0] = "Fresh";
CompilationTicketKind2[CompilationTicketKind2["IncrementalTypeScript"] = 1] = "IncrementalTypeScript";
CompilationTicketKind2[CompilationTicketKind2["IncrementalResource"] = 2] = "IncrementalResource";
})(CompilationTicketKind || (CompilationTicketKind = {}));
function freshCompilationTicket(tsProgram, options, incrementalBuildStrategy, programDriver, perfRecorder, enableTemplateTypeChecker, usePoisonedData) {
return {
kind: CompilationTicketKind.Fresh,
tsProgram,
options,
incrementalBuildStrategy,
programDriver,
enableTemplateTypeChecker,
usePoisonedData,
perfRecorder: perfRecorder != null ? perfRecorder : ActivePerfRecorder.zeroedToNow()
};
}
function incrementalFromCompilerTicket(oldCompiler, newProgram, incrementalBuildStrategy, programDriver, modifiedResourceFiles, perfRecorder) {
const oldProgram = oldCompiler.getCurrentProgram();
const oldState = oldCompiler.incrementalStrategy.getIncrementalState(oldProgram);
if (oldState === null) {
return freshCompilationTicket(newProgram, oldCompiler.options, incrementalBuildStrategy, programDriver, perfRecorder, oldCompiler.enableTemplateTypeChecker, oldCompiler.usePoisonedData);
}
if (perfRecorder === null) {
perfRecorder = ActivePerfRecorder.zeroedToNow();
}
const incrementalCompilation = IncrementalCompilation.incremental(newProgram, versionMapFromProgram(newProgram, programDriver), oldProgram, oldState, modifiedResourceFiles, perfRecorder);
return {
kind: CompilationTicketKind.IncrementalTypeScript,
enableTemplateTypeChecker: oldCompiler.enableTemplateTypeChecker,
usePoisonedData: oldCompiler.usePoisonedData,
options: oldCompiler.options,
incrementalBuildStrategy,
incrementalCompilation,
programDriver,
newProgram,
perfRecorder
};
}
function incrementalFromStateTicket(oldProgram, oldState, newProgram, options, incrementalBuildStrategy, programDriver, modifiedResourceFiles, perfRecorder, enableTemplateTypeChecker, usePoisonedData) {
if (perfRecorder === null) {
perfRecorder = ActivePerfRecorder.zeroedToNow();
}
const incrementalCompilation = IncrementalCompilation.incremental(newProgram, versionMapFromProgram(newProgram, programDriver), oldProgram, oldState, modifiedResourceFiles, perfRecorder);
return {
kind: CompilationTicketKind.IncrementalTypeScript,
newProgram,
options,
incrementalBuildStrategy,
incrementalCompilation,
programDriver,
enableTemplateTypeChecker,
usePoisonedData,
perfRecorder
};
}
var NgCompiler = class {
static fromTicket(ticket, adapter) {
switch (ticket.kind) {
case CompilationTicketKind.Fresh:
return new NgCompiler(adapter, ticket.options, ticket.tsProgram, ticket.programDriver, ticket.incrementalBuildStrategy, IncrementalCompilation.fresh(ticket.tsProgram, versionMapFromProgram(ticket.tsProgram, ticket.programDriver)), ticket.enableTemplateTypeChecker, ticket.usePoisonedData, ticket.perfRecorder);
case CompilationTicketKind.IncrementalTypeScript:
return new NgCompiler(adapter, ticket.options, ticket.newProgram, ticket.programDriver, ticket.incrementalBuildStrategy, ticket.incrementalCompilation, ticket.enableTemplateTypeChecker, ticket.usePoisonedData, ticket.perfRecorder);
case CompilationTicketKind.IncrementalResource:
const compiler = ticket.compiler;
compiler.updateWithChangedResources(ticket.modifiedResourceFiles, ticket.perfRecorder);
return compiler;
}
}
constructor(adapter, options, inputProgram, programDriver, incrementalStrategy, incrementalCompilation, enableTemplateTypeChecker, usePoisonedData, livePerfRecorder) {
var _a, _b;
this.adapter = adapter;
this.options = options;
this.inputProgram = inputProgram;
this.programDriver = programDriver;
this.incrementalStrategy = incrementalStrategy;
this.incrementalCompilation = incrementalCompilation;
this.usePoisonedData = usePoisonedData;
this.livePerfRecorder = livePerfRecorder;
this.compilation = null;
this.constructionDiagnostics = [];
this.nonTemplateDiagnostics = null;
this.delegatingPerfRecorder = new DelegatingPerfRecorder(this.perfRecorder);
this.enableTemplateTypeChecker = enableTemplateTypeChecker || ((_a = options["_enableTemplateTypeChecker"]) != null ? _a : false);
this.enableBlockSyntax = (_b = options["_enableBlockSyntax"]) != null ? _b : true;
this.constructionDiagnostics.push(...this.adapter.constructionDiagnostics, ...verifyCompatibleTypeCheckOptions(this.options));
this.currentProgram = inputProgram;
this.closureCompilerEnabled = !!this.options.annotateForClosureCompiler;
this.entryPoint = adapter.entryPoint !== null ? getSourceFileOrNull(inputProgram, adapter.entryPoint) : null;
const moduleResolutionCache = ts35.createModuleResolutionCache(
this.adapter.getCurrentDirectory(),
this.adapter.getCanonicalFileName.bind(this.adapter)
);
this.moduleResolver = new ModuleResolver(inputProgram, this.options, this.adapter, moduleResolutionCache);
this.resourceManager = new AdapterResourceLoader(adapter, this.options);
this.cycleAnalyzer = new CycleAnalyzer(new ImportGraph(inputProgram.getTypeChecker(), this.delegatingPerfRecorder));
this.incrementalStrategy.setIncrementalState(this.incrementalCompilation.state, inputProgram);
this.ignoreForDiagnostics = new Set(inputProgram.getSourceFiles().filter((sf) => this.adapter.isShim(sf)));
this.ignoreForEmit = this.adapter.ignoreForEmit;
let dtsFileCount = 0;
let nonDtsFileCount = 0;
for (const sf of inputProgram.getSourceFiles()) {
if (sf.isDeclarationFile) {
dtsFileCount++;
} else {
nonDtsFileCount++;
}
}
livePerfRecorder.eventCount(PerfEvent.InputDtsFile, dtsFileCount);
livePerfRecorder.eventCount(PerfEvent.InputTsFile, nonDtsFileCount);
}
get perfRecorder() {
return this.livePerfRecorder;
}
updateWithChangedResources(changedResources, perfRecorder) {
this.livePerfRecorder = perfRecorder;
this.delegatingPerfRecorder.target = perfRecorder;
perfRecorder.inPhase(PerfPhase.ResourceUpdate, () => {
if (this.compilation === null) {
return;
}
this.resourceManager.invalidate();
const classesToUpdate = /* @__PURE__ */ new Set();
for (const resourceFile of changedResources) {
for (const templateClass of this.getComponentsWithTemplateFile(resourceFile)) {
classesToUpdate.add(templateClass);
}
for (const styleClass of this.getComponentsWithStyleFile(resourceFile)) {
classesToUpdate.add(styleClass);
}
}
for (const clazz of classesToUpdate) {
this.compilation.traitCompiler.updateResources(clazz);
if (!ts35.isClassDeclaration(clazz)) {
continue;
}
this.compilation.templateTypeChecker.invalidateClass(clazz);
}
});
}
getResourceDependencies(file) {
this.ensureAnalyzed();
return this.incrementalCompilation.depGraph.getResourceDependencies(file);
}
getDiagnostics() {
const diagnostics = [
...this.getNonTemplateDiagnostics()
];
try {
diagnostics.push(...this.getTemplateDiagnostics());
if (this.options.strictTemplates) {
diagnostics.push(...this.getExtendedTemplateDiagnostics());
}
} catch (err) {
if (!isFatalDiagnosticError(err)) {
throw err;
}
diagnostics.push(err.toDiagnostic());
}
return this.addMessageTextDetails(diagnostics);
}
getDiagnosticsForFile(file, optimizeFor) {
const diagnostics = [...this.getNonTemplateDiagnostics().filter((diag) => diag.file === file)];
try {
diagnostics.push(...this.getTemplateDiagnosticsForFile(file, optimizeFor));
if (this.options.strictTemplates) {
diagnostics.push(...this.getExtendedTemplateDiagnostics(file));
}
} catch (err) {
if (!isFatalDiagnosticError(err)) {
throw err;
}
diagnostics.push(err.toDiagnostic());
}
return this.addMessageTextDetails(diagnostics);
}
getDiagnosticsForComponent(component) {
const compilation = this.ensureAnalyzed();
const ttc = compilation.templateTypeChecker;
const diagnostics = [];
try {
diagnostics.push(...ttc.getDiagnosticsForComponent(component));
const extendedTemplateChecker = compilation.extendedTemplateChecker;
if (this.options.strictTemplates && extendedTemplateChecker) {
diagnostics.push(...extendedTemplateChecker.getDiagnosticsForComponent(component));
}
} catch (err) {
if (!isFatalDiagnosticError(err)) {
throw err;
}
diagnostics.push(err.toDiagnostic());
}
return this.addMessageTextDetails(diagnostics);
}
addMessageTextDetails(diagnostics) {
return diagnostics.map((diag) => {
if (diag.code && COMPILER_ERRORS_WITH_GUIDES.has(ngErrorCode(diag.code))) {
return {
...diag,
messageText: diag.messageText + `. Find more at ${ERROR_DETAILS_PAGE_BASE_URL}/NG${ngErrorCode(diag.code)}`
};
}
return diag;
});
}
getOptionDiagnostics() {
return this.constructionDiagnostics;
}
getCurrentProgram() {
return this.currentProgram;
}
getTemplateTypeChecker() {
if (!this.enableTemplateTypeChecker) {
throw new Error("The `TemplateTypeChecker` does not work without `enableTemplateTypeChecker`.");
}
return this.ensureAnalyzed().templateTypeChecker;
}
getComponentsWithTemplateFile(templateFilePath) {
const { resourceRegistry } = this.ensureAnalyzed();
return resourceRegistry.getComponentsWithTemplate(resolve(templateFilePath));
}
getComponentsWithStyleFile(styleFilePath) {
const { resourceRegistry } = this.ensureAnalyzed();
return resourceRegistry.getComponentsWithStyle(resolve(styleFilePath));
}
getComponentResources(classDecl) {
if (!isNamedClassDeclaration(classDecl)) {
return null;
}
const { resourceRegistry } = this.ensureAnalyzed();
const styles = resourceRegistry.getStyles(classDecl);
const template = resourceRegistry.getTemplate(classDecl);
if (template === null) {
return null;
}
return { styles, template };
}
getMeta(classDecl) {
var _a;
if (!isNamedClassDeclaration(classDecl)) {
return null;
}
const ref = new Reference(classDecl);
const { metaReader } = this.ensureAnalyzed();
const meta = (_a = metaReader.getPipeMetadata(ref)) != null ? _a : metaReader.getDirectiveMetadata(ref);
if (meta === null) {
return null;
}
return meta;
}
async analyzeAsync() {
if (this.compilation !== null) {
return;
}
await this.perfRecorder.inPhase(PerfPhase.Analysis, async () => {
this.compilation = this.makeCompilation();
const promises = [];
for (const sf of this.inputProgram.getSourceFiles()) {
if (sf.isDeclarationFile) {
continue;
}
let analysisPromise = this.compilation.traitCompiler.analyzeAsync(sf);
if (analysisPromise !== void 0) {
promises.push(analysisPromise);
}
}
await Promise.all(promises);
this.perfRecorder.memory(PerfCheckpoint.Analysis);
this.resolveCompilation(this.compilation.traitCompiler);
});
}
prepareEmit() {
const compilation = this.ensureAnalyzed();
const coreImportsFrom = compilation.isCore ? getR3SymbolsFile(this.inputProgram) : null;
let importRewriter;
if (coreImportsFrom !== null) {
importRewriter = new R3SymbolsImportRewriter(coreImportsFrom.fileName);
} else {
importRewriter = new NoopImportRewriter();
}
const defaultImportTracker = new DefaultImportTracker();
const before = [
ivyTransformFactory(compilation.traitCompiler, compilation.reflector, importRewriter, defaultImportTracker, this.delegatingPerfRecorder, compilation.isCore, this.closureCompilerEnabled),
aliasTransformFactory(compilation.traitCompiler.exportStatements),
defaultImportTracker.importPreservingTransformer()
];
const afterDeclarations = [];
if (this.options.compilationMode !== "experimental-local" && compilation.dtsTransforms !== null) {
afterDeclarations.push(declarationTransformFactory(compilation.dtsTransforms, compilation.reflector, compilation.refEmitter, importRewriter));
}
if (compilation.aliasingHost !== null && compilation.aliasingHost.aliasExportsInDts) {
afterDeclarations.push(aliasTransformFactory(compilation.traitCompiler.exportStatements));
}
return { transformers: { before, afterDeclarations } };
}
getIndexedComponents() {
const compilation = this.ensureAnalyzed();
const context = new IndexingContext();
compilation.traitCompiler.index(context);
return generateAnalysis(context);
}
getApiDocumentation(entryPoint) {
const compilation = this.ensureAnalyzed();
const checker = this.inputProgram.getTypeChecker();
const docsExtractor = new DocsExtractor(checker, compilation.metaReader);
const entryPointSourceFile = this.inputProgram.getSourceFiles().find((sourceFile) => {
return sourceFile.fileName.includes(entryPoint);
});
if (!entryPointSourceFile) {
throw new Error(`Entry point "${entryPoint}" not found in program sources.`);
}
return docsExtractor.extractAll(entryPointSourceFile);
}
xi18n(ctx) {
const compilation = this.ensureAnalyzed();
compilation.traitCompiler.xi18n(ctx);
}
ensureAnalyzed() {
if (this.compilation === null) {
this.analyzeSync();
}
return this.compilation;
}
analyzeSync() {
this.perfRecorder.inPhase(PerfPhase.Analysis, () => {
this.compilation = this.makeCompilation();
for (const sf of this.inputProgram.getSourceFiles()) {
if (sf.isDeclarationFile) {
continue;
}
this.compilation.traitCompiler.analyzeSync(sf);
}
this.perfRecorder.memory(PerfCheckpoint.Analysis);
this.resolveCompilation(this.compilation.traitCompiler);
});
}
resolveCompilation(traitCompiler) {
this.perfRecorder.inPhase(PerfPhase.Resolve, () => {
traitCompiler.resolve();
this.incrementalCompilation.recordSuccessfulAnalysis(traitCompiler);
this.perfRecorder.memory(PerfCheckpoint.Resolve);
});
}
get fullTemplateTypeCheck() {
const strictTemplates = !!this.options.strictTemplates;
return strictTemplates || !!this.options.fullTemplateTypeCheck;
}
getTypeCheckingConfig() {
var _a, _b, _c, _d;
const strictTemplates = !!this.options.strictTemplates;
const useInlineTypeConstructors = this.programDriver.supportsInlineOperations;
let typeCheckingConfig;
if (this.fullTemplateTypeCheck) {
typeCheckingConfig = {
applyTemplateContextGuards: strictTemplates,
checkQueries: false,
checkTemplateBodies: true,
alwaysCheckSchemaInTemplateBodies: true,
checkTypeOfInputBindings: strictTemplates,
honorAccessModifiersForInputBindings: false,
strictNullInputBindings: strictTemplates,
checkTypeOfAttributes: strictTemplates,
checkTypeOfDomBindings: false,
checkTypeOfOutputEvents: strictTemplates,
checkTypeOfAnimationEvents: strictTemplates,
checkTypeOfDomEvents: strictTemplates,
checkTypeOfDomReferences: strictTemplates,
checkTypeOfNonDomReferences: true,
checkTypeOfPipes: true,
strictSafeNavigationTypes: strictTemplates,
useContextGenericType: strictTemplates,
strictLiteralTypes: true,
enableTemplateTypeChecker: this.enableTemplateTypeChecker,
useInlineTypeConstructors,
suggestionsForSuboptimalTypeInference: this.enableTemplateTypeChecker && !strictTemplates,
controlFlowPreventingContentProjection: ((_a = this.options.extendedDiagnostics) == null ? void 0 : _a.defaultCategory) || DiagnosticCategoryLabel.Warning
};
} else {
typeCheckingConfig = {
applyTemplateContextGuards: false,
checkQueries: false,
checkTemplateBodies: false,
alwaysCheckSchemaInTemplateBodies: this.closureCompilerEnabled,
checkTypeOfInputBindings: false,
strictNullInputBindings: false,
honorAccessModifiersForInputBindings: false,
checkTypeOfAttributes: false,
checkTypeOfDomBindings: false,
checkTypeOfOutputEvents: false,
checkTypeOfAnimationEvents: false,
checkTypeOfDomEvents: false,
checkTypeOfDomReferences: false,
checkTypeOfNonDomReferences: false,
checkTypeOfPipes: false,
strictSafeNavigationTypes: false,
useContextGenericType: false,
strictLiteralTypes: false,
enableTemplateTypeChecker: this.enableTemplateTypeChecker,
useInlineTypeConstructors,
suggestionsForSuboptimalTypeInference: false,
controlFlowPreventingContentProjection: ((_b = this.options.extendedDiagnostics) == null ? void 0 : _b.defaultCategory) || DiagnosticCategoryLabel.Warning
};
}
if (this.options.strictInputTypes !== void 0) {
typeCheckingConfig.checkTypeOfInputBindings = this.options.strictInputTypes;
typeCheckingConfig.applyTemplateContextGuards = this.options.strictInputTypes;
}
if (this.options.strictInputAccessModifiers !== void 0) {
typeCheckingConfig.honorAccessModifiersForInputBindings = this.options.strictInputAccessModifiers;
}
if (this.options.strictNullInputTypes !== void 0) {
typeCheckingConfig.strictNullInputBindings = this.options.strictNullInputTypes;
}
if (this.options.strictOutputEventTypes !== void 0) {
typeCheckingConfig.checkTypeOfOutputEvents = this.options.strictOutputEventTypes;
typeCheckingConfig.checkTypeOfAnimationEvents = this.options.strictOutputEventTypes;
}
if (this.options.strictDomEventTypes !== void 0) {
typeCheckingConfig.checkTypeOfDomEvents = this.options.strictDomEventTypes;
}
if (this.options.strictSafeNavigationTypes !== void 0) {
typeCheckingConfig.strictSafeNavigationTypes = this.options.strictSafeNavigationTypes;
}
if (this.options.strictDomLocalRefTypes !== void 0) {
typeCheckingConfig.checkTypeOfDomReferences = this.options.strictDomLocalRefTypes;
}
if (this.options.strictAttributeTypes !== void 0) {
typeCheckingConfig.checkTypeOfAttributes = this.options.strictAttributeTypes;
}
if (this.options.strictContextGenerics !== void 0) {
typeCheckingConfig.useContextGenericType = this.options.strictContextGenerics;
}
if (this.options.strictLiteralTypes !== void 0) {
typeCheckingConfig.strictLiteralTypes = this.options.strictLiteralTypes;
}
if (((_d = (_c = this.options.extendedDiagnostics) == null ? void 0 : _c.checks) == null ? void 0 : _d.controlFlowPreventingContentProjection) !== void 0) {
typeCheckingConfig.controlFlowPreventingContentProjection = this.options.extendedDiagnostics.checks.controlFlowPreventingContentProjection;
}
return typeCheckingConfig;
}
getTemplateDiagnostics() {
const compilation = this.ensureAnalyzed();
const diagnostics = [];
for (const sf of this.inputProgram.getSourceFiles()) {
if (sf.isDeclarationFile || this.adapter.isShim(sf)) {
continue;
}
diagnostics.push(...compilation.templateTypeChecker.getDiagnosticsForFile(sf, OptimizeFor.WholeProgram));
}
const program = this.programDriver.getProgram();
this.incrementalStrategy.setIncrementalState(this.incrementalCompilation.state, program);
this.currentProgram = program;
return diagnostics;
}
getTemplateDiagnosticsForFile(sf, optimizeFor) {
const compilation = this.ensureAnalyzed();
const diagnostics = [];
if (!sf.isDeclarationFile && !this.adapter.isShim(sf)) {
diagnostics.push(...compilation.templateTypeChecker.getDiagnosticsForFile(sf, optimizeFor));
}
const program = this.programDriver.getProgram();
this.incrementalStrategy.setIncrementalState(this.incrementalCompilation.state, program);
this.currentProgram = program;
return diagnostics;
}
getNonTemplateDiagnostics() {
if (this.nonTemplateDiagnostics === null) {
const compilation = this.ensureAnalyzed();
this.nonTemplateDiagnostics = [...compilation.traitCompiler.diagnostics];
if (this.entryPoint !== null && compilation.exportReferenceGraph !== null) {
this.nonTemplateDiagnostics.push(...checkForPrivateExports(this.entryPoint, this.inputProgram.getTypeChecker(), compilation.exportReferenceGraph));
}
}
return this.nonTemplateDiagnostics;
}
getExtendedTemplateDiagnostics(sf) {
const diagnostics = [];
const compilation = this.ensureAnalyzed();
const extendedTemplateChecker = compilation.extendedTemplateChecker;
if (!extendedTemplateChecker) {
return [];
}
if (sf !== void 0) {
return compilation.traitCompiler.extendedTemplateCheck(sf, extendedTemplateChecker);
}
for (const sf2 of this.inputProgram.getSourceFiles()) {
diagnostics.push(...compilation.traitCompiler.extendedTemplateCheck(sf2, extendedTemplateChecker));
}
return diagnostics;
}
makeCompilation() {
var _a, _b, _c, _d;
const isCore = isAngularCorePackage(this.inputProgram);
let compilationMode = CompilationMode.FULL;
if (!isCore) {
switch (this.options.compilationMode) {
case "full":
compilationMode = CompilationMode.FULL;
break;
case "partial":
compilationMode = CompilationMode.PARTIAL;
break;
case "experimental-local":
compilationMode = CompilationMode.LOCAL;
break;
}
}
const checker = this.inputProgram.getTypeChecker();
const reflector = new TypeScriptReflectionHost(checker, compilationMode === CompilationMode.LOCAL);
let refEmitter;
let aliasingHost = null;
if (this.adapter.unifiedModulesHost === null || !this.options["_useHostForImportGeneration"]) {
let localImportStrategy;
if (this.options.rootDir !== void 0 || this.options.rootDirs !== void 0 && this.options.rootDirs.length > 0) {
localImportStrategy = new LogicalProjectStrategy(reflector, new LogicalFileSystem([...this.adapter.rootDirs], this.adapter));
} else {
localImportStrategy = new RelativePathStrategy(reflector);
}
refEmitter = new ReferenceEmitter([
new LocalIdentifierStrategy(),
new AbsoluteModuleStrategy(this.inputProgram, checker, this.moduleResolver, reflector),
localImportStrategy
]);
if (this.entryPoint === null && this.options.generateDeepReexports === true) {
aliasingHost = new PrivateExportAliasingHost(reflector);
}
} else {
refEmitter = new ReferenceEmitter([
new LocalIdentifierStrategy(),
new AliasStrategy(),
new UnifiedModulesStrategy(reflector, this.adapter.unifiedModulesHost)
]);
aliasingHost = new UnifiedModulesAliasingHost(this.adapter.unifiedModulesHost);
}
const evaluator = new PartialEvaluator(reflector, checker, this.incrementalCompilation.depGraph);
const dtsReader = new DtsMetadataReader(checker, reflector);
const localMetaRegistry = new LocalMetadataRegistry();
const localMetaReader = localMetaRegistry;
const depScopeReader = new MetadataDtsModuleScopeResolver(dtsReader, aliasingHost);
const metaReader = new CompoundMetadataReader([localMetaReader, dtsReader]);
const ngModuleIndex = new NgModuleIndexImpl(metaReader, localMetaReader);
const ngModuleScopeRegistry = new LocalModuleScopeRegistry(localMetaReader, metaReader, depScopeReader, refEmitter, aliasingHost);
const standaloneScopeReader = new StandaloneComponentScopeReader(metaReader, ngModuleScopeRegistry, depScopeReader);
const scopeReader = new CompoundComponentScopeReader([ngModuleScopeRegistry, standaloneScopeReader]);
const semanticDepGraphUpdater = this.incrementalCompilation.semanticDepGraphUpdater;
const metaRegistry = new CompoundMetadataRegistry([localMetaRegistry, ngModuleScopeRegistry]);
const injectableRegistry = new InjectableClassRegistry(reflector, isCore);
const hostDirectivesResolver = new HostDirectivesResolver(metaReader);
const exportedProviderStatusResolver = new ExportedProviderStatusResolver(metaReader);
const typeCheckScopeRegistry = new TypeCheckScopeRegistry(scopeReader, metaReader, hostDirectivesResolver);
let referencesRegistry;
let exportReferenceGraph = null;
if (this.entryPoint !== null) {
exportReferenceGraph = new ReferenceGraph();
referencesRegistry = new ReferenceGraphAdapter(exportReferenceGraph);
} else {
referencesRegistry = new NoopReferencesRegistry();
}
const dtsTransforms = new DtsTransformRegistry();
const resourceRegistry = new ResourceRegistry();
const deferredSymbolsTracker = new DeferredSymbolTracker(this.inputProgram.getTypeChecker(), (_a = this.options.onlyExplicitDeferDependencyImports) != null ? _a : false);
const cycleHandlingStrategy = compilationMode === CompilationMode.FULL ? 0 : 1;
const strictCtorDeps = this.options.strictInjectionParameters || false;
const supportJitMode = (_b = this.options["supportJitMode"]) != null ? _b : true;
const supportTestBed = (_c = this.options["supportTestBed"]) != null ? _c : true;
if (supportTestBed === false && compilationMode === CompilationMode.PARTIAL) {
throw new Error('TestBed support ("supportTestBed" option) cannot be disabled in partial compilation mode.');
}
if (supportJitMode === false && compilationMode === CompilationMode.PARTIAL) {
throw new Error('JIT mode support ("supportJitMode" option) cannot be disabled in partial compilation mode.');
}
if (supportJitMode === false && this.options.forbidOrphanComponents) {
throw new Error('JIT mode support ("supportJitMode" option) cannot be disabled when forbidOrphanComponents is set to true');
}
const handlers = [
new ComponentDecoratorHandler(reflector, evaluator, metaRegistry, metaReader, scopeReader, depScopeReader, ngModuleScopeRegistry, typeCheckScopeRegistry, resourceRegistry, isCore, strictCtorDeps, this.resourceManager, this.adapter.rootDirs, this.options.preserveWhitespaces || false, this.options.i18nUseExternalIds !== false, this.options.enableI18nLegacyMessageIdFormat !== false, this.usePoisonedData, this.options.i18nNormalizeLineEndingsInICUs === true, this.moduleResolver, this.cycleAnalyzer, cycleHandlingStrategy, refEmitter, referencesRegistry, this.incrementalCompilation.depGraph, injectableRegistry, semanticDepGraphUpdater, this.closureCompilerEnabled, this.delegatingPerfRecorder, hostDirectivesResolver, supportTestBed, compilationMode, deferredSymbolsTracker, !!this.options.forbidOrphanComponents, this.enableBlockSyntax),
new DirectiveDecoratorHandler(reflector, evaluator, metaRegistry, ngModuleScopeRegistry, metaReader, injectableRegistry, refEmitter, referencesRegistry, isCore, strictCtorDeps, semanticDepGraphUpdater, this.closureCompilerEnabled, this.delegatingPerfRecorder, supportTestBed, compilationMode),
new PipeDecoratorHandler(reflector, evaluator, metaRegistry, ngModuleScopeRegistry, injectableRegistry, isCore, this.delegatingPerfRecorder, supportTestBed, compilationMode),
new InjectableDecoratorHandler(reflector, evaluator, isCore, strictCtorDeps, injectableRegistry, this.delegatingPerfRecorder, supportTestBed, compilationMode),
new NgModuleDecoratorHandler(reflector, evaluator, metaReader, metaRegistry, ngModuleScopeRegistry, referencesRegistry, exportedProviderStatusResolver, semanticDepGraphUpdater, isCore, refEmitter, this.closureCompilerEnabled, (_d = this.options.onlyPublishPublicTypingsForNgModules) != null ? _d : false, injectableRegistry, this.delegatingPerfRecorder, supportTestBed, supportJitMode, compilationMode)
];
const traitCompiler = new TraitCompiler(handlers, reflector, this.delegatingPerfRecorder, this.incrementalCompilation, this.options.compileNonExportedClasses !== false, compilationMode, dtsTransforms, semanticDepGraphUpdater, this.adapter);
const notifyingDriver = new NotifyingProgramDriverWrapper(this.programDriver, (program) => {
this.incrementalStrategy.setIncrementalState(this.incrementalCompilation.state, program);
this.currentProgram = program;
});
const templateTypeChecker = new TemplateTypeCheckerImpl(this.inputProgram, notifyingDriver, traitCompiler, this.getTypeCheckingConfig(), refEmitter, reflector, this.adapter, this.incrementalCompilation, metaReader, localMetaReader, ngModuleIndex, scopeReader, typeCheckScopeRegistry, this.delegatingPerfRecorder);
const extendedTemplateChecker = this.constructionDiagnostics.length === 0 ? new ExtendedTemplateCheckerImpl(templateTypeChecker, checker, ALL_DIAGNOSTIC_FACTORIES, this.options) : null;
return {
isCore,
traitCompiler,
reflector,
scopeRegistry: ngModuleScopeRegistry,
dtsTransforms,
exportReferenceGraph,
metaReader,
typeCheckScopeRegistry,
aliasingHost,
refEmitter,
templateTypeChecker,
resourceRegistry,
extendedTemplateChecker
};
}
};
function isAngularCorePackage(program) {
const r3Symbols = getR3SymbolsFile(program);
if (r3Symbols === null) {
return false;
}
return r3Symbols.statements.some((stmt) => {
if (!ts35.isVariableStatement(stmt)) {
return false;
}
const modifiers = ts35.getModifiers(stmt);
if (modifiers === void 0 || !modifiers.some((mod) => mod.kind === ts35.SyntaxKind.ExportKeyword)) {
return false;
}
return stmt.declarationList.declarations.some((decl) => {
if (!ts35.isIdentifier(decl.name) || decl.name.text !== "ITS_JUST_ANGULAR") {
return false;
}
if (decl.initializer === void 0 || decl.initializer.kind !== ts35.SyntaxKind.TrueKeyword) {
return false;
}
return true;
});
});
}
function getR3SymbolsFile(program) {
return program.getSourceFiles().find((file) => file.fileName.indexOf("r3_symbols.ts") >= 0) || null;
}
function* verifyCompatibleTypeCheckOptions(options) {
var _a, _b, _c;
if (options.fullTemplateTypeCheck === false && options.strictTemplates === true) {
yield makeConfigDiagnostic({
category: ts35.DiagnosticCategory.Error,
code: ErrorCode.CONFIG_STRICT_TEMPLATES_IMPLIES_FULL_TEMPLATE_TYPECHECK,
messageText: `
Angular compiler option "strictTemplates" is enabled, however "fullTemplateTypeCheck" is disabled.
Having the "strictTemplates" flag enabled implies that "fullTemplateTypeCheck" is also enabled, so
the latter can not be explicitly disabled.
One of the following actions is required:
1. Remove the "fullTemplateTypeCheck" option.
2. Remove "strictTemplates" or set it to 'false'.
More information about the template type checking compiler options can be found in the documentation:
https://angular.io/guide/template-typecheck
`.trim()
});
}
if (options.extendedDiagnostics && options.strictTemplates === false) {
yield makeConfigDiagnostic({
category: ts35.DiagnosticCategory.Error,
code: ErrorCode.CONFIG_EXTENDED_DIAGNOSTICS_IMPLIES_STRICT_TEMPLATES,
messageText: `
Angular compiler option "extendedDiagnostics" is configured, however "strictTemplates" is disabled.
Using "extendedDiagnostics" requires that "strictTemplates" is also enabled.
One of the following actions is required:
1. Remove "strictTemplates: false" to enable it.
2. Remove "extendedDiagnostics" configuration to disable them.
`.trim()
});
}
const allowedCategoryLabels = Array.from(Object.values(DiagnosticCategoryLabel));
const defaultCategory = (_a = options.extendedDiagnostics) == null ? void 0 : _a.defaultCategory;
if (defaultCategory && !allowedCategoryLabels.includes(defaultCategory)) {
yield makeConfigDiagnostic({
category: ts35.DiagnosticCategory.Error,
code: ErrorCode.CONFIG_EXTENDED_DIAGNOSTICS_UNKNOWN_CATEGORY_LABEL,
messageText: `
Angular compiler option "extendedDiagnostics.defaultCategory" has an unknown diagnostic category: "${defaultCategory}".
Allowed diagnostic categories are:
${allowedCategoryLabels.join("\n")}
`.trim()
});
}
for (const [checkName, category] of Object.entries((_c = (_b = options.extendedDiagnostics) == null ? void 0 : _b.checks) != null ? _c : {})) {
if (!SUPPORTED_DIAGNOSTIC_NAMES.has(checkName)) {
yield makeConfigDiagnostic({
category: ts35.DiagnosticCategory.Error,
code: ErrorCode.CONFIG_EXTENDED_DIAGNOSTICS_UNKNOWN_CHECK,
messageText: `
Angular compiler option "extendedDiagnostics.checks" has an unknown check: "${checkName}".
Allowed check names are:
${Array.from(SUPPORTED_DIAGNOSTIC_NAMES).join("\n")}
`.trim()
});
}
if (!allowedCategoryLabels.includes(category)) {
yield makeConfigDiagnostic({
category: ts35.DiagnosticCategory.Error,
code: ErrorCode.CONFIG_EXTENDED_DIAGNOSTICS_UNKNOWN_CATEGORY_LABEL,
messageText: `
Angular compiler option "extendedDiagnostics.checks['${checkName}']" has an unknown diagnostic category: "${category}".
Allowed diagnostic categories are:
${allowedCategoryLabels.join("\n")}
`.trim()
});
}
}
}
function makeConfigDiagnostic({ category, code, messageText }) {
return {
category,
code: ngErrorCode(code),
file: void 0,
start: void 0,
length: void 0,
messageText
};
}
var ReferenceGraphAdapter = class {
constructor(graph) {
this.graph = graph;
}
add(source, ...references) {
for (const { node } of references) {
let sourceFile = node.getSourceFile();
if (sourceFile === void 0) {
sourceFile = ts35.getOriginalNode(node).getSourceFile();
}
if (sourceFile === void 0 || !isDtsPath(sourceFile.fileName)) {
this.graph.add(source, node);
}
}
}
};
var NotifyingProgramDriverWrapper = class {
constructor(delegate, notifyNewProgram) {
var _a;
this.delegate = delegate;
this.notifyNewProgram = notifyNewProgram;
this.getSourceFileVersion = (_a = this.delegate.getSourceFileVersion) == null ? void 0 : _a.bind(this);
}
get supportsInlineOperations() {
return this.delegate.supportsInlineOperations;
}
getProgram() {
return this.delegate.getProgram();
}
updateFiles(contents, updateMode) {
this.delegate.updateFiles(contents, updateMode);
this.notifyNewProgram(this.delegate.getProgram());
}
};
function versionMapFromProgram(program, driver) {
if (driver.getSourceFileVersion === void 0) {
return null;
}
const versions = /* @__PURE__ */ new Map();
for (const possiblyRedirectedSourceFile of program.getSourceFiles()) {
const sf = toUnredirectedSourceFile(possiblyRedirectedSourceFile);
versions.set(absoluteFromSourceFile(sf), driver.getSourceFileVersion(sf));
}
return versions;
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/core/src/host.mjs
import ts36 from "typescript";
var DelegatingCompilerHost2 = class {
get jsDocParsingMode() {
return this.delegate.jsDocParsingMode;
}
set jsDocParsingMode(mode) {
this.delegate.jsDocParsingMode = mode;
}
constructor(delegate) {
this.delegate = delegate;
this.createHash = this.delegateMethod("createHash");
this.directoryExists = this.delegateMethod("directoryExists");
this.fileNameToModuleName = this.delegateMethod("fileNameToModuleName");
this.getCancellationToken = this.delegateMethod("getCancellationToken");
this.getCanonicalFileName = this.delegateMethod("getCanonicalFileName");
this.getCurrentDirectory = this.delegateMethod("getCurrentDirectory");
this.getDefaultLibFileName = this.delegateMethod("getDefaultLibFileName");
this.getDefaultLibLocation = this.delegateMethod("getDefaultLibLocation");
this.getDirectories = this.delegateMethod("getDirectories");
this.getEnvironmentVariable = this.delegateMethod("getEnvironmentVariable");
this.getModifiedResourceFiles = this.delegateMethod("getModifiedResourceFiles");
this.getNewLine = this.delegateMethod("getNewLine");
this.getParsedCommandLine = this.delegateMethod("getParsedCommandLine");
this.getSourceFileByPath = this.delegateMethod("getSourceFileByPath");
this.readDirectory = this.delegateMethod("readDirectory");
this.readFile = this.delegateMethod("readFile");
this.readResource = this.delegateMethod("readResource");
this.transformResource = this.delegateMethod("transformResource");
this.realpath = this.delegateMethod("realpath");
this.resolveModuleNames = this.delegateMethod("resolveModuleNames");
this.resolveTypeReferenceDirectives = this.delegateMethod("resolveTypeReferenceDirectives");
this.resourceNameToFileName = this.delegateMethod("resourceNameToFileName");
this.trace = this.delegateMethod("trace");
this.useCaseSensitiveFileNames = this.delegateMethod("useCaseSensitiveFileNames");
this.writeFile = this.delegateMethod("writeFile");
this.getModuleResolutionCache = this.delegateMethod("getModuleResolutionCache");
this.hasInvalidatedResolutions = this.delegateMethod("hasInvalidatedResolutions");
this.resolveModuleNameLiterals = this.delegateMethod("resolveModuleNameLiterals");
this.resolveTypeReferenceDirectiveReferences = this.delegateMethod("resolveTypeReferenceDirectiveReferences");
}
delegateMethod(name) {
return this.delegate[name] !== void 0 ? this.delegate[name].bind(this.delegate) : void 0;
}
};
var NgCompilerHost = class extends DelegatingCompilerHost2 {
constructor(delegate, inputFiles, rootDirs, shimAdapter, shimTagger, entryPoint, diagnostics) {
super(delegate);
this.shimAdapter = shimAdapter;
this.shimTagger = shimTagger;
this.entryPoint = null;
this.entryPoint = entryPoint;
this.constructionDiagnostics = diagnostics;
this.inputFiles = [...inputFiles, ...shimAdapter.extraInputFiles];
this.rootDirs = rootDirs;
if (this.resolveModuleNames === void 0) {
this.resolveModuleNames = this.createCachedResolveModuleNamesFunction();
}
}
get ignoreForEmit() {
return this.shimAdapter.ignoreForEmit;
}
get shimExtensionPrefixes() {
return this.shimAdapter.extensionPrefixes;
}
postProgramCreationCleanup() {
this.shimTagger.finalize();
}
static wrap(delegate, inputFiles, options, oldProgram) {
const topLevelShimGenerators = [];
const perFileShimGenerators = [];
const rootDirs = getRootDirs(delegate, options);
perFileShimGenerators.push(new TypeCheckShimGenerator());
let diagnostics = [];
const normalizedTsInputFiles = [];
for (const inputFile of inputFiles) {
if (!isNonDeclarationTsPath(inputFile)) {
continue;
}
normalizedTsInputFiles.push(resolve(inputFile));
}
let entryPoint = null;
if (options.flatModuleOutFile != null && options.flatModuleOutFile !== "") {
entryPoint = findFlatIndexEntryPoint(normalizedTsInputFiles);
if (entryPoint === null) {
diagnostics.push({
category: ts36.DiagnosticCategory.Error,
code: ngErrorCode(ErrorCode.CONFIG_FLAT_MODULE_NO_INDEX),
file: void 0,
start: void 0,
length: void 0,
messageText: 'Angular compiler option "flatModuleOutFile" requires one and only one .ts file in the "files" field.'
});
} else {
const flatModuleId = options.flatModuleId || null;
const flatModuleOutFile = normalizeSeparators(options.flatModuleOutFile);
const flatIndexGenerator = new FlatIndexGenerator(entryPoint, flatModuleOutFile, flatModuleId);
topLevelShimGenerators.push(flatIndexGenerator);
}
}
const shimAdapter = new ShimAdapter(delegate, normalizedTsInputFiles, topLevelShimGenerators, perFileShimGenerators, oldProgram);
const shimTagger = new ShimReferenceTagger(perFileShimGenerators.map((gen) => gen.extensionPrefix));
return new NgCompilerHost(delegate, inputFiles, rootDirs, shimAdapter, shimTagger, entryPoint, diagnostics);
}
isShim(sf) {
return isShim(sf);
}
isResource(sf) {
return false;
}
getSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile) {
const shimSf = this.shimAdapter.maybeGenerate(resolve(fileName));
if (shimSf !== null) {
return shimSf;
}
const sf = this.delegate.getSourceFile(fileName, languageVersionOrOptions, onError, shouldCreateNewSourceFile);
if (sf === void 0) {
return void 0;
}
this.shimTagger.tag(sf);
return sf;
}
fileExists(fileName) {
return this.delegate.fileExists(fileName) || this.shimAdapter.maybeGenerate(resolve(fileName)) != null;
}
get unifiedModulesHost() {
return this.fileNameToModuleName !== void 0 ? this : null;
}
createCachedResolveModuleNamesFunction() {
const moduleResolutionCache = ts36.createModuleResolutionCache(this.getCurrentDirectory(), this.getCanonicalFileName.bind(this));
return (moduleNames, containingFile, reusedNames, redirectedReference, options) => {
return moduleNames.map((moduleName) => {
const module = ts36.resolveModuleName(moduleName, containingFile, options, this, moduleResolutionCache, redirectedReference);
return module.resolvedModule;
});
};
}
};
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/ngtsc/program.mjs
var NgtscProgram = class {
constructor(rootNames, options, delegateHost, oldProgram) {
this.options = options;
const perfRecorder = ActivePerfRecorder.zeroedToNow();
perfRecorder.phase(PerfPhase.Setup);
if (!options.disableTypeScriptVersionCheck) {
verifySupportedTypeScriptVersion();
}
if (options.compilationMode === "experimental-local") {
options.noEmitOnError = false;
}
const reuseProgram = oldProgram == null ? void 0 : oldProgram.compiler.getCurrentProgram();
this.host = NgCompilerHost.wrap(delegateHost, rootNames, options, reuseProgram != null ? reuseProgram : null);
if (reuseProgram !== void 0) {
retagAllTsFiles(reuseProgram);
}
this.tsProgram = perfRecorder.inPhase(PerfPhase.TypeScriptProgramCreate, () => ts37.createProgram(this.host.inputFiles, options, this.host, reuseProgram));
perfRecorder.phase(PerfPhase.Unaccounted);
perfRecorder.memory(PerfCheckpoint.TypeScriptProgramCreate);
this.host.postProgramCreationCleanup();
untagAllTsFiles(this.tsProgram);
const programDriver = new TsCreateProgramDriver(this.tsProgram, this.host, this.options, this.host.shimExtensionPrefixes);
this.incrementalStrategy = oldProgram !== void 0 ? oldProgram.incrementalStrategy.toNextBuildStrategy() : new TrackedIncrementalBuildStrategy();
const modifiedResourceFiles = /* @__PURE__ */ new Set();
if (this.host.getModifiedResourceFiles !== void 0) {
const strings = this.host.getModifiedResourceFiles();
if (strings !== void 0) {
for (const fileString of strings) {
modifiedResourceFiles.add(absoluteFrom(fileString));
}
}
}
let ticket;
if (oldProgram === void 0) {
ticket = freshCompilationTicket(
this.tsProgram,
options,
this.incrementalStrategy,
programDriver,
perfRecorder,
false,
false
);
} else {
ticket = incrementalFromCompilerTicket(oldProgram.compiler, this.tsProgram, this.incrementalStrategy, programDriver, modifiedResourceFiles, perfRecorder);
}
this.compiler = NgCompiler.fromTicket(ticket, this.host);
}
getTsProgram() {
return this.tsProgram;
}
getReuseTsProgram() {
return this.compiler.getCurrentProgram();
}
getTsOptionDiagnostics(cancellationToken) {
return this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptDiagnostics, () => this.tsProgram.getOptionsDiagnostics(cancellationToken));
}
getTsSyntacticDiagnostics(sourceFile, cancellationToken) {
return this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptDiagnostics, () => {
const ignoredFiles = this.compiler.ignoreForDiagnostics;
let res;
if (sourceFile !== void 0) {
if (ignoredFiles.has(sourceFile)) {
return [];
}
res = this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);
} else {
const diagnostics = [];
for (const sf of this.tsProgram.getSourceFiles()) {
if (!ignoredFiles.has(sf)) {
diagnostics.push(...this.tsProgram.getSyntacticDiagnostics(sf, cancellationToken));
}
}
res = diagnostics;
}
return res;
});
}
getTsSemanticDiagnostics(sourceFile, cancellationToken) {
if (this.options.compilationMode === "experimental-local") {
return [];
}
return this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptDiagnostics, () => {
const ignoredFiles = this.compiler.ignoreForDiagnostics;
let res;
if (sourceFile !== void 0) {
if (ignoredFiles.has(sourceFile)) {
return [];
}
res = this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);
} else {
const diagnostics = [];
for (const sf of this.tsProgram.getSourceFiles()) {
if (!ignoredFiles.has(sf)) {
diagnostics.push(...this.tsProgram.getSemanticDiagnostics(sf, cancellationToken));
}
}
res = diagnostics;
}
return res;
});
}
getNgOptionDiagnostics(cancellationToken) {
return this.compiler.getOptionDiagnostics();
}
getNgStructuralDiagnostics(cancellationToken) {
return [];
}
getNgSemanticDiagnostics(fileName, cancellationToken) {
let sf = void 0;
if (fileName !== void 0) {
sf = this.tsProgram.getSourceFile(fileName);
if (sf === void 0) {
return [];
}
}
if (sf === void 0) {
return this.compiler.getDiagnostics();
} else {
return this.compiler.getDiagnosticsForFile(sf, OptimizeFor.WholeProgram);
}
}
loadNgStructureAsync() {
return this.compiler.analyzeAsync();
}
listLazyRoutes(entryRoute) {
return [];
}
emitXi18n() {
var _a, _b, _c;
const ctx = new MessageBundle(new HtmlParser(), [], {}, (_a = this.options.i18nOutLocale) != null ? _a : null);
this.compiler.xi18n(ctx);
i18nExtract((_b = this.options.i18nOutFormat) != null ? _b : null, (_c = this.options.i18nOutFile) != null ? _c : null, this.host, this.options, ctx, resolve);
}
emit(opts) {
var _a;
if (opts !== void 0 && opts.emitFlags !== void 0 && opts.emitFlags & EmitFlags.I18nBundle) {
this.emitXi18n();
if (!(opts.emitFlags & EmitFlags.JS)) {
return {
diagnostics: [],
emitSkipped: true,
emittedFiles: []
};
}
}
const forceEmit = (_a = opts == null ? void 0 : opts.forceEmit) != null ? _a : false;
this.compiler.perfRecorder.memory(PerfCheckpoint.PreEmit);
const res = this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptEmit, () => {
var _a2;
const { transformers } = this.compiler.prepareEmit();
const ignoreFiles = this.compiler.ignoreForEmit;
const emitCallback = (_a2 = opts == null ? void 0 : opts.emitCallback) != null ? _a2 : defaultEmitCallback;
const writeFile = (fileName, data, writeByteOrderMark, onError, sourceFiles) => {
if (sourceFiles !== void 0) {
for (const writtenSf of sourceFiles) {
if (writtenSf.isDeclarationFile) {
continue;
}
this.compiler.incrementalCompilation.recordSuccessfulEmit(writtenSf);
}
}
this.host.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);
};
const customTransforms = opts && opts.customTransformers;
const beforeTransforms = transformers.before || [];
const afterDeclarationsTransforms = transformers.afterDeclarations;
if (customTransforms !== void 0 && customTransforms.beforeTs !== void 0) {
beforeTransforms.push(...customTransforms.beforeTs);
}
const emitResults = [];
for (const targetSourceFile of this.tsProgram.getSourceFiles()) {
if (targetSourceFile.isDeclarationFile || ignoreFiles.has(targetSourceFile)) {
continue;
}
if (!forceEmit && this.compiler.incrementalCompilation.safeToSkipEmit(targetSourceFile)) {
this.compiler.perfRecorder.eventCount(PerfEvent.EmitSkipSourceFile);
continue;
}
this.compiler.perfRecorder.eventCount(PerfEvent.EmitSourceFile);
emitResults.push(emitCallback({
targetSourceFile,
program: this.tsProgram,
host: this.host,
options: this.options,
emitOnlyDtsFiles: false,
writeFile,
customTransformers: {
before: beforeTransforms,
after: customTransforms && customTransforms.afterTs,
afterDeclarations: afterDeclarationsTransforms
}
}));
}
this.compiler.perfRecorder.memory(PerfCheckpoint.Emit);
return (opts && opts.mergeEmitResultsCallback || mergeEmitResults)(emitResults);
});
if (this.options.tracePerformance !== void 0) {
const perf = this.compiler.perfRecorder.finalize();
getFileSystem().writeFile(getFileSystem().resolve(this.options.tracePerformance), JSON.stringify(perf, null, 2));
}
return res;
}
getIndexedComponents() {
return this.compiler.getIndexedComponents();
}
getApiDocumentation(entryPoint) {
return this.compiler.getApiDocumentation(entryPoint);
}
getEmittedSourceFiles() {
throw new Error("Method not implemented.");
}
};
var defaultEmitCallback = ({ program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers }) => program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);
function mergeEmitResults(emitResults) {
const diagnostics = [];
let emitSkipped = false;
const emittedFiles = [];
for (const er of emitResults) {
diagnostics.push(...er.diagnostics);
emitSkipped = emitSkipped || er.emitSkipped;
emittedFiles.push(...er.emittedFiles || []);
}
return { diagnostics, emitSkipped, emittedFiles };
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/transformers/program.mjs
function createProgram({ rootNames, options, host, oldProgram }) {
return new NgtscProgram(rootNames, options, host, oldProgram);
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/perform_compile.mjs
import ts39 from "typescript";
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/transformers/util.mjs
import ts38 from "typescript";
function createMessageDiagnostic(messageText) {
return {
file: void 0,
start: void 0,
length: void 0,
category: ts38.DiagnosticCategory.Message,
messageText,
code: DEFAULT_ERROR_CODE,
source: SOURCE
};
}
// bazel-out/k8-fastbuild/bin/packages/compiler-cli/src/perform_compile.mjs
var defaultFormatHost = {
getCurrentDirectory: () => ts39.sys.getCurrentDirectory(),
getCanonicalFileName: (fileName) => fileName,
getNewLine: () => ts39.sys.newLine
};
function formatDiagnostics(diags, host = defaultFormatHost) {
if (diags && diags.length) {
return diags.map((diagnostic) => replaceTsWithNgInErrors(ts39.formatDiagnosticsWithColorAndContext([diagnostic], host))).join("");
} else {
return "";
}
}
function calcProjectFileAndBasePath(project, host = getFileSystem()) {
const absProject = host.resolve(project);
const projectIsDir = host.lstat(absProject).isDirectory();
const projectFile = projectIsDir ? host.join(absProject, "tsconfig.json") : absProject;
const projectDir = projectIsDir ? absProject : host.dirname(absProject);
const basePath = host.resolve(projectDir);
return { projectFile, basePath };
}
function readConfiguration(project, existingOptions, host = getFileSystem()) {
var _a;
try {
const fs = getFileSystem();
const readConfigFile = (configFile) => ts39.readConfigFile(configFile, (file) => host.readFile(host.resolve(file)));
const readAngularCompilerOptions = (configFile, parentOptions = {}) => {
const { config: config2, error: error2 } = readConfigFile(configFile);
if (error2) {
return parentOptions;
}
let existingNgCompilerOptions = { ...config2.angularCompilerOptions, ...parentOptions };
if (!config2.extends) {
return existingNgCompilerOptions;
}
const extendsPaths = typeof config2.extends === "string" ? [config2.extends] : config2.extends;
return [...extendsPaths].reverse().reduce((prevOptions, extendsPath) => {
const extendedConfigPath = getExtendedConfigPath(configFile, extendsPath, host, fs);
return extendedConfigPath === null ? prevOptions : readAngularCompilerOptions(extendedConfigPath, prevOptions);
}, existingNgCompilerOptions);
};
const { projectFile, basePath } = calcProjectFileAndBasePath(project, host);
const configFileName = host.resolve(host.pwd(), projectFile);
const { config, error } = readConfigFile(projectFile);
if (error) {
return {
project,
errors: [error],
rootNames: [],
options: {},
emitFlags: EmitFlags.Default
};
}
const existingCompilerOptions = {
genDir: basePath,
basePath,
...readAngularCompilerOptions(configFileName),
...existingOptions
};
const parseConfigHost = createParseConfigHost(host, fs);
const { options, errors, fileNames: rootNames, projectReferences } = ts39.parseJsonConfigFileContent(config, parseConfigHost, basePath, existingCompilerOptions, configFileName);
let emitFlags = EmitFlags.Default;
if (!(options["skipMetadataEmit"] || options["flatModuleOutFile"])) {
emitFlags |= EmitFlags.Metadata;
}
if (options["skipTemplateCodegen"]) {
emitFlags = emitFlags & ~EmitFlags.Codegen;
}
return { project: projectFile, rootNames, projectReferences, options, errors, emitFlags };
} catch (e) {
const errors = [{
category: ts39.DiagnosticCategory.Error,
messageText: (_a = e.stack) != null ? _a : e.message,
file: void 0,
start: void 0,
length: void 0,
source: "angular",
code: UNKNOWN_ERROR_CODE
}];
return { project: "", errors, rootNames: [], options: {}, emitFlags: EmitFlags.Default };
}
}
function createParseConfigHost(host, fs = getFileSystem()) {
return {
fileExists: host.exists.bind(host),
readDirectory: ts39.sys.readDirectory,
readFile: host.readFile.bind(host),
useCaseSensitiveFileNames: fs.isCaseSensitive()
};
}
function getExtendedConfigPath(configFile, extendsValue, host, fs) {
const result = getExtendedConfigPathWorker(configFile, extendsValue, host, fs);
if (result !== null) {
return result;
}
return getExtendedConfigPathWorker(configFile, `${extendsValue}.json`, host, fs);
}
function getExtendedConfigPathWorker(configFile, extendsValue, host, fs) {
if (extendsValue.startsWith(".") || fs.isRooted(extendsValue)) {
const extendedConfigPath = host.resolve(host.dirname(configFile), extendsValue);
if (host.exists(extendedConfigPath)) {
return extendedConfigPath;
}
} else {
const parseConfigHost = createParseConfigHost(host, fs);
const { resolvedModule } = ts39.nodeModuleNameResolver(extendsValue, configFile, { moduleResolution: ts39.ModuleResolutionKind.Node10, resolveJsonModule: true }, parseConfigHost);
if (resolvedModule) {
return absoluteFrom(resolvedModule.resolvedFileName);
}
}
return null;
}
function exitCodeFromResult(diags) {
if (!diags)
return 0;
if (diags.every((diag) => diag.category !== ts39.DiagnosticCategory.Error)) {
return 0;
}
return diags.some((d) => d.source === "angular" && d.code === UNKNOWN_ERROR_CODE) ? 2 : 1;
}
function performCompilation({ rootNames, options, host, oldProgram, emitCallback, mergeEmitResultsCallback, gatherDiagnostics = defaultGatherDiagnostics, customTransformers, emitFlags = EmitFlags.Default, forceEmit = false, modifiedResourceFiles = null }) {
var _a;
let program;
let emitResult;
let allDiagnostics = [];
try {
if (!host) {
host = createCompilerHost({ options });
}
if (modifiedResourceFiles) {
host.getModifiedResourceFiles = () => modifiedResourceFiles;
}
program = createProgram({ rootNames, host, options, oldProgram });
const beforeDiags = Date.now();
allDiagnostics.push(...gatherDiagnostics(program));
if (options.diagnostics) {
const afterDiags = Date.now();
allDiagnostics.push(createMessageDiagnostic(`Time for diagnostics: ${afterDiags - beforeDiags}ms.`));
}
if (!hasErrors(allDiagnostics)) {
emitResult = program.emit({ emitCallback, mergeEmitResultsCallback, customTransformers, emitFlags, forceEmit });
allDiagnostics.push(...emitResult.diagnostics);
return { diagnostics: allDiagnostics, program, emitResult };
}
return { diagnostics: allDiagnostics, program };
} catch (e) {
program = void 0;
allDiagnostics.push({
category: ts39.DiagnosticCategory.Error,
messageText: (_a = e.stack) != null ? _a : e.message,
code: UNKNOWN_ERROR_CODE,
file: void 0,
start: void 0,
length: void 0
});
return { diagnostics: allDiagnostics, program };
}
}
function defaultGatherDiagnostics(program) {
const allDiagnostics = [];
function checkDiagnostics(diags) {
if (diags) {
allDiagnostics.push(...diags);
return !hasErrors(diags);
}
return true;
}
let checkOtherDiagnostics = true;
checkOtherDiagnostics = checkOtherDiagnostics && checkDiagnostics([...program.getTsOptionDiagnostics(), ...program.getNgOptionDiagnostics()]);
checkOtherDiagnostics = checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics());
checkOtherDiagnostics = checkOtherDiagnostics && checkDiagnostics([...program.getTsSemanticDiagnostics(), ...program.getNgStructuralDiagnostics()]);
checkOtherDiagnostics = checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics());
return allDiagnostics;
}
function hasErrors(diags) {
return diags.some((d) => d.category === ts39.DiagnosticCategory.Error);
}
export {
DEFAULT_ERROR_CODE,
UNKNOWN_ERROR_CODE,
SOURCE,
isTsDiagnostic,
EmitFlags,
createCompilerHost,
EntryType,
MemberType,
DecoratorType,
MemberTags,
untagAllTsFiles,
TsCreateProgramDriver,
PatchedProgramIncrementalBuildStrategy,
freshCompilationTicket,
incrementalFromStateTicket,
NgCompiler,
NgCompilerHost,
NgtscProgram,
createProgram,
createMessageDiagnostic,
formatDiagnostics,
calcProjectFileAndBasePath,
readConfiguration,
exitCodeFromResult,
performCompilation,
defaultGatherDiagnostics
};
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
//# sourceMappingURL=chunk-ELKFSTAE.js.map