import {createRequire as __cjsCompatRequire} from 'module'; const require = __cjsCompatRequire(import.meta.url); import { Context, ExpressionTranslatorVisitor } from "./chunk-O2GHHXCL.js"; import { SourceFileLoader } from "./chunk-2WQIUGOU.js"; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/fatal_linker_error.mjs var FatalLinkerError = class extends Error { constructor(node, message) { super(message); this.node = node; this.type = "FatalLinkerError"; } }; function isFatalLinkerError(e) { return e && e.type === "FatalLinkerError"; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/ast/utils.mjs function assert(node, predicate, expected) { if (!predicate(node)) { throw new FatalLinkerError(node, `Unsupported syntax, expected ${expected}.`); } } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/ast/ast_value.mjs import * as o from "@angular/compiler"; var AstObject = class { static parse(expression, host) { const obj = host.parseObjectLiteral(expression); return new AstObject(expression, obj, host); } constructor(expression, obj, host) { this.expression = expression; this.obj = obj; this.host = host; } has(propertyName) { return this.obj.has(propertyName); } getNumber(propertyName) { return this.host.parseNumericLiteral(this.getRequiredProperty(propertyName)); } getString(propertyName) { return this.host.parseStringLiteral(this.getRequiredProperty(propertyName)); } getBoolean(propertyName) { return this.host.parseBooleanLiteral(this.getRequiredProperty(propertyName)); } getObject(propertyName) { const expr = this.getRequiredProperty(propertyName); const obj = this.host.parseObjectLiteral(expr); return new AstObject(expr, obj, this.host); } getArray(propertyName) { const arr = this.host.parseArrayLiteral(this.getRequiredProperty(propertyName)); return arr.map((entry) => new AstValue(entry, this.host)); } getOpaque(propertyName) { return new o.WrappedNodeExpr(this.getRequiredProperty(propertyName)); } getNode(propertyName) { return this.getRequiredProperty(propertyName); } getValue(propertyName) { return new AstValue(this.getRequiredProperty(propertyName), this.host); } toLiteral(mapper) { const result = {}; for (const [key, expression] of this.obj) { result[key] = mapper(new AstValue(expression, this.host), key); } return result; } toMap(mapper) { const result = /* @__PURE__ */ new Map(); for (const [key, expression] of this.obj) { result.set(key, mapper(new AstValue(expression, this.host))); } return result; } getRequiredProperty(propertyName) { if (!this.obj.has(propertyName)) { throw new FatalLinkerError(this.expression, `Expected property '${propertyName}' to be present.`); } return this.obj.get(propertyName); } }; var AstValue = class { constructor(expression, host) { this.expression = expression; this.host = host; this.\u0275typeBrand = null; } getSymbolName() { return this.host.getSymbolName(this.expression); } isNumber() { return this.host.isNumericLiteral(this.expression); } getNumber() { return this.host.parseNumericLiteral(this.expression); } isString() { return this.host.isStringLiteral(this.expression); } getString() { return this.host.parseStringLiteral(this.expression); } isBoolean() { return this.host.isBooleanLiteral(this.expression); } getBoolean() { return this.host.parseBooleanLiteral(this.expression); } isObject() { return this.host.isObjectLiteral(this.expression); } getObject() { return AstObject.parse(this.expression, this.host); } isArray() { return this.host.isArrayLiteral(this.expression); } isNull() { return this.host.isNull(this.expression); } getArray() { const arr = this.host.parseArrayLiteral(this.expression); return arr.map((entry) => new AstValue(entry, this.host)); } isFunction() { return this.host.isFunctionExpression(this.expression); } getFunctionReturnValue() { return new AstValue(this.host.parseReturnValue(this.expression), this.host); } isCallExpression() { return this.host.isCallExpression(this.expression); } getCallee() { return new AstValue(this.host.parseCallee(this.expression), this.host); } getArguments() { const args = this.host.parseArguments(this.expression); return args.map((arg) => new AstValue(arg, this.host)); } getOpaque() { return new o.WrappedNodeExpr(this.expression); } getRange() { return this.host.getRange(this.expression); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/emit_scopes/emit_scope.mjs import { ConstantPool } from "@angular/compiler"; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/linker_import_generator.mjs var LinkerImportGenerator = class { constructor(ngImport) { this.ngImport = ngImport; } generateNamespaceImport(moduleName) { this.assertModuleName(moduleName); return this.ngImport; } generateNamedImport(moduleName, originalSymbol) { this.assertModuleName(moduleName); return { moduleImport: this.ngImport, symbol: originalSymbol }; } assertModuleName(moduleName) { if (moduleName !== "@angular/core") { throw new FatalLinkerError(this.ngImport, `Unable to import from anything other than '@angular/core'`); } } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/emit_scopes/emit_scope.mjs var EmitScope = class { constructor(ngImport, translator, factory) { this.ngImport = ngImport; this.translator = translator; this.factory = factory; this.constantPool = new ConstantPool(); } translateDefinition(definition) { const expression = this.translator.translateExpression(definition.expression, new LinkerImportGenerator(this.ngImport)); if (definition.statements.length > 0) { const importGenerator = new LinkerImportGenerator(this.ngImport); return this.wrapInIifeWithStatements(expression, definition.statements.map((statement) => this.translator.translateStatement(statement, importGenerator))); } else { return expression; } } getConstantStatements() { const importGenerator = new LinkerImportGenerator(this.ngImport); return this.constantPool.statements.map((statement) => this.translator.translateStatement(statement, importGenerator)); } wrapInIifeWithStatements(expression, statements) { const returnStatement = this.factory.createReturnStatement(expression); const body = this.factory.createBlock([...statements, returnStatement]); const fn = this.factory.createFunctionExpression(null, [], body); return this.factory.createCallExpression(fn, [], false); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/emit_scopes/local_emit_scope.mjs var LocalEmitScope = class extends EmitScope { translateDefinition(definition) { return super.translateDefinition({ expression: definition.expression, statements: [...this.constantPool.statements, ...definition.statements] }); } getConstantStatements() { throw new Error("BUG - LocalEmitScope should not expose any constant statements"); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.mjs import semver2 from "semver"; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/get_source_file.mjs function createGetSourceFile(sourceUrl, code, loader) { if (loader === null) { return () => null; } else { let sourceFile = void 0; return () => { if (sourceFile === void 0) { sourceFile = loader.loadSourceFile(sourceUrl, code); } return sourceFile; }; } } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_class_metadata_linker_1.mjs import { compileClassMetadata } from "@angular/compiler"; var PartialClassMetadataLinkerVersion1 = class { linkPartialDeclaration(constantPool, metaObj) { const meta = toR3ClassMetadata(metaObj); return { expression: compileClassMetadata(meta), statements: [] }; } }; function toR3ClassMetadata(metaObj) { return { type: metaObj.getOpaque("type"), decorators: metaObj.getOpaque("decorators"), ctorParameters: metaObj.has("ctorParameters") ? metaObj.getOpaque("ctorParameters") : null, propDecorators: metaObj.has("propDecorators") ? metaObj.getOpaque("propDecorators") : null }; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_component_linker_1.mjs import { ChangeDetectionStrategy, compileComponentFromMetadata, DEFAULT_INTERPOLATION_CONFIG, InterpolationConfig, makeBindingParser as makeBindingParser2, parseTemplate, R3TargetBinder, R3TemplateDependencyKind, SelectorMatcher, ViewEncapsulation } from "@angular/compiler"; import semver from "semver"; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_directive_linker_1.mjs import { compileDirectiveFromMetadata, makeBindingParser, ParseLocation, ParseSourceFile, ParseSourceSpan } from "@angular/compiler"; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/util.mjs import { createMayBeForwardRefExpression, outputAst as o2 } from "@angular/compiler"; var PLACEHOLDER_VERSION = "17.1.3"; function wrapReference(wrapped) { return { value: wrapped, type: wrapped }; } function parseEnum(value, Enum) { const symbolName = value.getSymbolName(); if (symbolName === null) { throw new FatalLinkerError(value.expression, "Expected value to have a symbol name"); } const enumValue = Enum[symbolName]; if (enumValue === void 0) { throw new FatalLinkerError(value.expression, `Unsupported enum value for ${Enum}`); } return enumValue; } function getDependency(depObj) { const isAttribute = depObj.has("attribute") && depObj.getBoolean("attribute"); const token = depObj.getOpaque("token"); const attributeNameType = isAttribute ? o2.literal("unknown") : null; return { token, attributeNameType, host: depObj.has("host") && depObj.getBoolean("host"), optional: depObj.has("optional") && depObj.getBoolean("optional"), self: depObj.has("self") && depObj.getBoolean("self"), skipSelf: depObj.has("skipSelf") && depObj.getBoolean("skipSelf") }; } function extractForwardRef(expr) { if (!expr.isCallExpression()) { return createMayBeForwardRefExpression(expr.getOpaque(), 0); } const callee = expr.getCallee(); if (callee.getSymbolName() !== "forwardRef") { throw new FatalLinkerError(callee.expression, "Unsupported expression, expected a `forwardRef()` call or a type reference"); } const args = expr.getArguments(); if (args.length !== 1) { throw new FatalLinkerError(expr, "Unsupported `forwardRef(fn)` call, expected a single argument"); } const wrapperFn = args[0]; if (!wrapperFn.isFunction()) { throw new FatalLinkerError(wrapperFn, "Unsupported `forwardRef(fn)` call, expected its argument to be a function"); } return createMayBeForwardRefExpression(wrapperFn.getFunctionReturnValue().getOpaque(), 2); } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_directive_linker_1.mjs var PartialDirectiveLinkerVersion1 = class { constructor(sourceUrl, code) { this.sourceUrl = sourceUrl; this.code = code; } linkPartialDeclaration(constantPool, metaObj) { const meta = toR3DirectiveMeta(metaObj, this.code, this.sourceUrl); return compileDirectiveFromMetadata(meta, constantPool, makeBindingParser()); } }; function toR3DirectiveMeta(metaObj, code, sourceUrl) { const typeExpr = metaObj.getValue("type"); const typeName = typeExpr.getSymbolName(); if (typeName === null) { throw new FatalLinkerError(typeExpr.expression, "Unsupported type, its name could not be determined"); } return { typeSourceSpan: createSourceSpan(typeExpr.getRange(), code, sourceUrl), type: wrapReference(typeExpr.getOpaque()), typeArgumentCount: 0, deps: null, host: toHostMetadata(metaObj), inputs: metaObj.has("inputs") ? metaObj.getObject("inputs").toLiteral(toInputMapping) : {}, outputs: metaObj.has("outputs") ? metaObj.getObject("outputs").toLiteral((value) => value.getString()) : {}, queries: metaObj.has("queries") ? metaObj.getArray("queries").map((entry) => toQueryMetadata(entry.getObject())) : [], viewQueries: metaObj.has("viewQueries") ? metaObj.getArray("viewQueries").map((entry) => toQueryMetadata(entry.getObject())) : [], providers: metaObj.has("providers") ? metaObj.getOpaque("providers") : null, fullInheritance: false, selector: metaObj.has("selector") ? metaObj.getString("selector") : null, exportAs: metaObj.has("exportAs") ? metaObj.getArray("exportAs").map((entry) => entry.getString()) : null, lifecycle: { usesOnChanges: metaObj.has("usesOnChanges") ? metaObj.getBoolean("usesOnChanges") : false }, name: typeName, usesInheritance: metaObj.has("usesInheritance") ? metaObj.getBoolean("usesInheritance") : false, isStandalone: metaObj.has("isStandalone") ? metaObj.getBoolean("isStandalone") : false, isSignal: metaObj.has("isSignal") ? metaObj.getBoolean("isSignal") : false, hostDirectives: metaObj.has("hostDirectives") ? toHostDirectivesMetadata(metaObj.getValue("hostDirectives")) : null }; } function toInputMapping(value, key) { if (value.isObject()) { const obj = value.getObject(); const transformValue = obj.getValue("transformFunction"); return { classPropertyName: obj.getString("classPropertyName"), bindingPropertyName: obj.getString("publicName"), isSignal: obj.getBoolean("isSignal"), required: obj.getBoolean("isRequired"), transformFunction: transformValue.isNull() ? null : transformValue.getOpaque() }; } return parseLegacyInputPartialOutput(key, value); } function parseLegacyInputPartialOutput(key, value) { if (value.isString()) { return { bindingPropertyName: value.getString(), classPropertyName: key, required: false, transformFunction: null, isSignal: false }; } const values = value.getArray(); if (values.length !== 2 && values.length !== 3) { throw new FatalLinkerError(value.expression, "Unsupported input, expected a string or an array containing two strings and an optional function"); } return { bindingPropertyName: values[0].getString(), classPropertyName: values[1].getString(), transformFunction: values.length > 2 ? values[2].getOpaque() : null, required: false, isSignal: false }; } function toHostMetadata(metaObj) { if (!metaObj.has("host")) { return { attributes: {}, listeners: {}, properties: {}, specialAttributes: {} }; } const host = metaObj.getObject("host"); const specialAttributes = {}; if (host.has("styleAttribute")) { specialAttributes.styleAttr = host.getString("styleAttribute"); } if (host.has("classAttribute")) { specialAttributes.classAttr = host.getString("classAttribute"); } return { attributes: host.has("attributes") ? host.getObject("attributes").toLiteral((value) => value.getOpaque()) : {}, listeners: host.has("listeners") ? host.getObject("listeners").toLiteral((value) => value.getString()) : {}, properties: host.has("properties") ? host.getObject("properties").toLiteral((value) => value.getString()) : {}, specialAttributes }; } function toQueryMetadata(obj) { let predicate; const predicateExpr = obj.getValue("predicate"); if (predicateExpr.isArray()) { predicate = predicateExpr.getArray().map((entry) => entry.getString()); } else { predicate = extractForwardRef(predicateExpr); } return { propertyName: obj.getString("propertyName"), first: obj.has("first") ? obj.getBoolean("first") : false, predicate, descendants: obj.has("descendants") ? obj.getBoolean("descendants") : false, emitDistinctChangesOnly: obj.has("emitDistinctChangesOnly") ? obj.getBoolean("emitDistinctChangesOnly") : true, read: obj.has("read") ? obj.getOpaque("read") : null, static: obj.has("static") ? obj.getBoolean("static") : false }; } function toHostDirectivesMetadata(hostDirectives) { return hostDirectives.getArray().map((hostDirective) => { const hostObject = hostDirective.getObject(); const type = extractForwardRef(hostObject.getValue("directive")); const meta = { directive: wrapReference(type.expression), isForwardReference: type.forwardRef !== 0, inputs: hostObject.has("inputs") ? getHostDirectiveBindingMapping(hostObject.getArray("inputs")) : null, outputs: hostObject.has("outputs") ? getHostDirectiveBindingMapping(hostObject.getArray("outputs")) : null }; return meta; }); } function getHostDirectiveBindingMapping(array) { let result = null; for (let i = 1; i < array.length; i += 2) { result = result || {}; result[array[i - 1].getString()] = array[i].getString(); } return result; } function createSourceSpan(range, code, sourceUrl) { const sourceFile = new ParseSourceFile(code, sourceUrl); const startLocation = new ParseLocation(sourceFile, range.startPos, range.startLine, range.startCol); return new ParseSourceSpan(startLocation, startLocation.moveBy(range.endPos - range.startPos)); } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_component_linker_1.mjs function makeDirectiveMetadata(directiveExpr, typeExpr, isComponentByDefault = null) { return { kind: R3TemplateDependencyKind.Directive, isComponent: isComponentByDefault || directiveExpr.has("kind") && directiveExpr.getString("kind") === "component", type: typeExpr, selector: directiveExpr.getString("selector"), inputs: directiveExpr.has("inputs") ? directiveExpr.getArray("inputs").map((input) => input.getString()) : [], outputs: directiveExpr.has("outputs") ? directiveExpr.getArray("outputs").map((input) => input.getString()) : [], exportAs: directiveExpr.has("exportAs") ? directiveExpr.getArray("exportAs").map((exportAs) => exportAs.getString()) : null }; } var PartialComponentLinkerVersion1 = class { constructor(getSourceFile, sourceUrl, code) { this.getSourceFile = getSourceFile; this.sourceUrl = sourceUrl; this.code = code; } linkPartialDeclaration(constantPool, metaObj, version) { const meta = this.toR3ComponentMeta(metaObj, version); return compileComponentFromMetadata(meta, constantPool, makeBindingParser2()); } toR3ComponentMeta(metaObj, version) { const interpolation = parseInterpolationConfig(metaObj); const templateSource = metaObj.getValue("template"); const isInline = metaObj.has("isInline") ? metaObj.getBoolean("isInline") : false; const templateInfo = this.getTemplateInfo(templateSource, isInline); const enableBlockSyntax = semver.major(version) >= 17 || version === PLACEHOLDER_VERSION; const template = parseTemplate(templateInfo.code, templateInfo.sourceUrl, { escapedString: templateInfo.isEscaped, interpolationConfig: interpolation, range: templateInfo.range, enableI18nLegacyMessageIdFormat: false, preserveWhitespaces: metaObj.has("preserveWhitespaces") ? metaObj.getBoolean("preserveWhitespaces") : false, i18nNormalizeLineEndingsInICUs: isInline, enableBlockSyntax }); if (template.errors !== null) { const errors = template.errors.map((err) => err.toString()).join("\n"); throw new FatalLinkerError(templateSource.expression, `Errors found in the template: ${errors}`); } const binder = new R3TargetBinder(new SelectorMatcher()); const boundTarget = binder.bind({ template: template.nodes }); let declarationListEmitMode = 0; const extractDeclarationTypeExpr = (type) => { const { expression, forwardRef } = extractForwardRef(type); if (forwardRef === 2) { declarationListEmitMode = 1; } return expression; }; let declarations = []; if (metaObj.has("components")) { declarations.push(...metaObj.getArray("components").map((dir) => { const dirExpr = dir.getObject(); const typeExpr = extractDeclarationTypeExpr(dirExpr.getValue("type")); return makeDirectiveMetadata(dirExpr, typeExpr, true); })); } if (metaObj.has("directives")) { declarations.push(...metaObj.getArray("directives").map((dir) => { const dirExpr = dir.getObject(); const typeExpr = extractDeclarationTypeExpr(dirExpr.getValue("type")); return makeDirectiveMetadata(dirExpr, typeExpr); })); } if (metaObj.has("pipes")) { const pipes = metaObj.getObject("pipes").toMap((pipe) => pipe); for (const [name, type] of pipes) { const typeExpr = extractDeclarationTypeExpr(type); declarations.push({ kind: R3TemplateDependencyKind.Pipe, name, type: typeExpr }); } } if (metaObj.has("dependencies")) { for (const dep of metaObj.getArray("dependencies")) { const depObj = dep.getObject(); const typeExpr = extractDeclarationTypeExpr(depObj.getValue("type")); switch (depObj.getString("kind")) { case "directive": case "component": declarations.push(makeDirectiveMetadata(depObj, typeExpr)); break; case "pipe": const pipeObj = depObj; declarations.push({ kind: R3TemplateDependencyKind.Pipe, name: pipeObj.getString("name"), type: typeExpr }); break; case "ngmodule": declarations.push({ kind: R3TemplateDependencyKind.NgModule, type: typeExpr }); break; default: continue; } } } return { ...toR3DirectiveMeta(metaObj, this.code, this.sourceUrl), viewProviders: metaObj.has("viewProviders") ? metaObj.getOpaque("viewProviders") : null, template: { nodes: template.nodes, ngContentSelectors: template.ngContentSelectors }, declarationListEmitMode, styles: metaObj.has("styles") ? metaObj.getArray("styles").map((entry) => entry.getString()) : [], deferBlocks: this.createR3DeferredMetadata(boundTarget), deferrableDeclToImportDecl: /* @__PURE__ */ new Map(), deferrableTypes: /* @__PURE__ */ new Map(), deferBlockDepsEmitMode: 0, encapsulation: metaObj.has("encapsulation") ? parseEncapsulation(metaObj.getValue("encapsulation")) : ViewEncapsulation.Emulated, interpolation, changeDetection: metaObj.has("changeDetection") ? parseChangeDetectionStrategy(metaObj.getValue("changeDetection")) : ChangeDetectionStrategy.Default, animations: metaObj.has("animations") ? metaObj.getOpaque("animations") : null, relativeContextFilePath: this.sourceUrl, i18nUseExternalIds: false, declarations }; } getTemplateInfo(templateNode, isInline) { const range = templateNode.getRange(); if (!isInline) { const externalTemplate = this.tryExternalTemplate(range); if (externalTemplate !== null) { return externalTemplate; } } return this.templateFromPartialCode(templateNode, range); } tryExternalTemplate(range) { const sourceFile = this.getSourceFile(); if (sourceFile === null) { return null; } const pos = sourceFile.getOriginalLocation(range.startLine, range.startCol); if (pos === null || pos.file === this.sourceUrl || /\.[jt]s$/.test(pos.file) || pos.line !== 0 || pos.column !== 0) { return null; } const templateContents = sourceFile.sources.find((src) => (src == null ? void 0 : src.sourcePath) === pos.file).contents; return { code: templateContents, sourceUrl: pos.file, range: { startPos: 0, startLine: 0, startCol: 0, endPos: templateContents.length }, isEscaped: false }; } templateFromPartialCode(templateNode, { startPos, endPos, startLine, startCol }) { if (!/["'`]/.test(this.code[startPos]) || this.code[startPos] !== this.code[endPos - 1]) { throw new FatalLinkerError(templateNode.expression, `Expected the template string to be wrapped in quotes but got: ${this.code.substring(startPos, endPos)}`); } return { code: this.code, sourceUrl: this.sourceUrl, range: { startPos: startPos + 1, endPos: endPos - 1, startLine, startCol: startCol + 1 }, isEscaped: true }; } createR3DeferredMetadata(boundTarget) { const deferredBlocks = boundTarget.getDeferBlocks(); const meta = /* @__PURE__ */ new Map(); for (const block of deferredBlocks) { const triggerElements = /* @__PURE__ */ new Map(); this.resolveDeferTriggers(block, block.triggers, boundTarget, triggerElements); this.resolveDeferTriggers(block, block.prefetchTriggers, boundTarget, triggerElements); meta.set(block, { deps: [], triggerElements }); } return meta; } resolveDeferTriggers(block, triggers, boundTarget, triggerElements) { Object.keys(triggers).forEach((key) => { const trigger = triggers[key]; triggerElements.set(trigger, boundTarget.getDeferredTriggerTarget(block, trigger)); }); } }; function parseInterpolationConfig(metaObj) { if (!metaObj.has("interpolation")) { return DEFAULT_INTERPOLATION_CONFIG; } const interpolationExpr = metaObj.getValue("interpolation"); const values = interpolationExpr.getArray().map((entry) => entry.getString()); if (values.length !== 2) { throw new FatalLinkerError(interpolationExpr.expression, "Unsupported interpolation config, expected an array containing exactly two strings"); } return InterpolationConfig.fromArray(values); } function parseEncapsulation(encapsulation) { const symbolName = encapsulation.getSymbolName(); if (symbolName === null) { throw new FatalLinkerError(encapsulation.expression, "Expected encapsulation to have a symbol name"); } const enumValue = ViewEncapsulation[symbolName]; if (enumValue === void 0) { throw new FatalLinkerError(encapsulation.expression, "Unsupported encapsulation"); } return enumValue; } function parseChangeDetectionStrategy(changeDetectionStrategy) { const symbolName = changeDetectionStrategy.getSymbolName(); if (symbolName === null) { throw new FatalLinkerError(changeDetectionStrategy.expression, "Expected change detection strategy to have a symbol name"); } const enumValue = ChangeDetectionStrategy[symbolName]; if (enumValue === void 0) { throw new FatalLinkerError(changeDetectionStrategy.expression, "Unsupported change detection strategy"); } return enumValue; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_factory_linker_1.mjs import { compileFactoryFunction, FactoryTarget } from "@angular/compiler"; var PartialFactoryLinkerVersion1 = class { linkPartialDeclaration(constantPool, metaObj) { const meta = toR3FactoryMeta(metaObj); return compileFactoryFunction(meta); } }; function toR3FactoryMeta(metaObj) { const typeExpr = metaObj.getValue("type"); const typeName = typeExpr.getSymbolName(); if (typeName === null) { throw new FatalLinkerError(typeExpr.expression, "Unsupported type, its name could not be determined"); } return { name: typeName, type: wrapReference(typeExpr.getOpaque()), typeArgumentCount: 0, target: parseEnum(metaObj.getValue("target"), FactoryTarget), deps: getDependencies(metaObj, "deps") }; } function getDependencies(metaObj, propName) { if (!metaObj.has(propName)) { return null; } const deps = metaObj.getValue(propName); if (deps.isArray()) { return deps.getArray().map((dep) => getDependency(dep.getObject())); } if (deps.isString()) { return "invalid"; } return null; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_injectable_linker_1.mjs import { compileInjectable, createMayBeForwardRefExpression as createMayBeForwardRefExpression2, outputAst as o3 } from "@angular/compiler"; var PartialInjectableLinkerVersion1 = class { linkPartialDeclaration(constantPool, metaObj) { const meta = toR3InjectableMeta(metaObj); return compileInjectable(meta, false); } }; function toR3InjectableMeta(metaObj) { const typeExpr = metaObj.getValue("type"); const typeName = typeExpr.getSymbolName(); if (typeName === null) { throw new FatalLinkerError(typeExpr.expression, "Unsupported type, its name could not be determined"); } const meta = { name: typeName, type: wrapReference(typeExpr.getOpaque()), typeArgumentCount: 0, providedIn: metaObj.has("providedIn") ? extractForwardRef(metaObj.getValue("providedIn")) : createMayBeForwardRefExpression2(o3.literal(null), 0) }; if (metaObj.has("useClass")) { meta.useClass = extractForwardRef(metaObj.getValue("useClass")); } if (metaObj.has("useFactory")) { meta.useFactory = metaObj.getOpaque("useFactory"); } if (metaObj.has("useExisting")) { meta.useExisting = extractForwardRef(metaObj.getValue("useExisting")); } if (metaObj.has("useValue")) { meta.useValue = extractForwardRef(metaObj.getValue("useValue")); } if (metaObj.has("deps")) { meta.deps = metaObj.getArray("deps").map((dep) => getDependency(dep.getObject())); } return meta; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_injector_linker_1.mjs import { compileInjector } from "@angular/compiler"; var PartialInjectorLinkerVersion1 = class { linkPartialDeclaration(constantPool, metaObj) { const meta = toR3InjectorMeta(metaObj); return compileInjector(meta); } }; function toR3InjectorMeta(metaObj) { const typeExpr = metaObj.getValue("type"); const typeName = typeExpr.getSymbolName(); if (typeName === null) { throw new FatalLinkerError(typeExpr.expression, "Unsupported type, its name could not be determined"); } return { name: typeName, type: wrapReference(typeExpr.getOpaque()), providers: metaObj.has("providers") ? metaObj.getOpaque("providers") : null, imports: metaObj.has("imports") ? metaObj.getArray("imports").map((i) => i.getOpaque()) : [] }; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_ng_module_linker_1.mjs import { compileNgModule, R3NgModuleMetadataKind, R3SelectorScopeMode } from "@angular/compiler"; var PartialNgModuleLinkerVersion1 = class { constructor(emitInline) { this.emitInline = emitInline; } linkPartialDeclaration(constantPool, metaObj) { const meta = toR3NgModuleMeta(metaObj, this.emitInline); return compileNgModule(meta); } }; function toR3NgModuleMeta(metaObj, supportJit) { const wrappedType = metaObj.getOpaque("type"); const meta = { kind: R3NgModuleMetadataKind.Global, type: wrapReference(wrappedType), bootstrap: [], declarations: [], publicDeclarationTypes: null, includeImportTypes: true, imports: [], exports: [], selectorScopeMode: supportJit ? R3SelectorScopeMode.Inline : R3SelectorScopeMode.Omit, containsForwardDecls: false, schemas: [], id: metaObj.has("id") ? metaObj.getOpaque("id") : null }; if (metaObj.has("bootstrap")) { const bootstrap = metaObj.getValue("bootstrap"); if (bootstrap.isFunction()) { meta.containsForwardDecls = true; meta.bootstrap = wrapReferences(unwrapForwardRefs(bootstrap)); } else meta.bootstrap = wrapReferences(bootstrap); } if (metaObj.has("declarations")) { const declarations = metaObj.getValue("declarations"); if (declarations.isFunction()) { meta.containsForwardDecls = true; meta.declarations = wrapReferences(unwrapForwardRefs(declarations)); } else meta.declarations = wrapReferences(declarations); } if (metaObj.has("imports")) { const imports = metaObj.getValue("imports"); if (imports.isFunction()) { meta.containsForwardDecls = true; meta.imports = wrapReferences(unwrapForwardRefs(imports)); } else meta.imports = wrapReferences(imports); } if (metaObj.has("exports")) { const exports = metaObj.getValue("exports"); if (exports.isFunction()) { meta.containsForwardDecls = true; meta.exports = wrapReferences(unwrapForwardRefs(exports)); } else meta.exports = wrapReferences(exports); } if (metaObj.has("schemas")) { const schemas = metaObj.getValue("schemas"); meta.schemas = wrapReferences(schemas); } return meta; } function unwrapForwardRefs(field) { return field.getFunctionReturnValue(); } function wrapReferences(values) { return values.getArray().map((i) => wrapReference(i.getOpaque())); } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_pipe_linker_1.mjs import { compilePipeFromMetadata } from "@angular/compiler"; var PartialPipeLinkerVersion1 = class { constructor() { } linkPartialDeclaration(constantPool, metaObj) { const meta = toR3PipeMeta(metaObj); return compilePipeFromMetadata(meta); } }; function toR3PipeMeta(metaObj) { const typeExpr = metaObj.getValue("type"); const typeName = typeExpr.getSymbolName(); if (typeName === null) { throw new FatalLinkerError(typeExpr.expression, "Unsupported type, its name could not be determined"); } const pure = metaObj.has("pure") ? metaObj.getBoolean("pure") : true; const isStandalone = metaObj.has("isStandalone") ? metaObj.getBoolean("isStandalone") : false; return { name: typeName, type: wrapReference(typeExpr.getOpaque()), typeArgumentCount: 0, deps: null, pipeName: metaObj.getString("name"), pure, isStandalone }; } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.mjs var \u0275\u0275ngDeclareDirective = "\u0275\u0275ngDeclareDirective"; var \u0275\u0275ngDeclareClassMetadata = "\u0275\u0275ngDeclareClassMetadata"; var \u0275\u0275ngDeclareComponent = "\u0275\u0275ngDeclareComponent"; var \u0275\u0275ngDeclareFactory = "\u0275\u0275ngDeclareFactory"; var \u0275\u0275ngDeclareInjectable = "\u0275\u0275ngDeclareInjectable"; var \u0275\u0275ngDeclareInjector = "\u0275\u0275ngDeclareInjector"; var \u0275\u0275ngDeclareNgModule = "\u0275\u0275ngDeclareNgModule"; var \u0275\u0275ngDeclarePipe = "\u0275\u0275ngDeclarePipe"; var declarationFunctions = [ \u0275\u0275ngDeclareDirective, \u0275\u0275ngDeclareClassMetadata, \u0275\u0275ngDeclareComponent, \u0275\u0275ngDeclareFactory, \u0275\u0275ngDeclareInjectable, \u0275\u0275ngDeclareInjector, \u0275\u0275ngDeclareNgModule, \u0275\u0275ngDeclarePipe ]; function createLinkerMap(environment, sourceUrl, code) { const linkers = /* @__PURE__ */ new Map(); const LATEST_VERSION_RANGE = getRange("<=", PLACEHOLDER_VERSION); linkers.set(\u0275\u0275ngDeclareDirective, [ { range: LATEST_VERSION_RANGE, linker: new PartialDirectiveLinkerVersion1(sourceUrl, code) } ]); linkers.set(\u0275\u0275ngDeclareClassMetadata, [ { range: LATEST_VERSION_RANGE, linker: new PartialClassMetadataLinkerVersion1() } ]); linkers.set(\u0275\u0275ngDeclareComponent, [ { range: LATEST_VERSION_RANGE, linker: new PartialComponentLinkerVersion1(createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl, code) } ]); linkers.set(\u0275\u0275ngDeclareFactory, [ { range: LATEST_VERSION_RANGE, linker: new PartialFactoryLinkerVersion1() } ]); linkers.set(\u0275\u0275ngDeclareInjectable, [ { range: LATEST_VERSION_RANGE, linker: new PartialInjectableLinkerVersion1() } ]); linkers.set(\u0275\u0275ngDeclareInjector, [ { range: LATEST_VERSION_RANGE, linker: new PartialInjectorLinkerVersion1() } ]); linkers.set(\u0275\u0275ngDeclareNgModule, [ { range: LATEST_VERSION_RANGE, linker: new PartialNgModuleLinkerVersion1(environment.options.linkerJitMode) } ]); linkers.set(\u0275\u0275ngDeclarePipe, [ { range: LATEST_VERSION_RANGE, linker: new PartialPipeLinkerVersion1() } ]); return linkers; } var PartialLinkerSelector = class { constructor(linkers, logger, unknownDeclarationVersionHandling) { this.linkers = linkers; this.logger = logger; this.unknownDeclarationVersionHandling = unknownDeclarationVersionHandling; } supportsDeclaration(functionName) { return this.linkers.has(functionName); } getLinker(functionName, minVersion, version) { if (!this.linkers.has(functionName)) { throw new Error(`Unknown partial declaration function ${functionName}.`); } const linkerRanges = this.linkers.get(functionName); if (version === PLACEHOLDER_VERSION) { return linkerRanges[linkerRanges.length - 1].linker; } const declarationRange = getRange(">=", minVersion); for (const { range: linkerRange, linker } of linkerRanges) { if (semver2.intersects(declarationRange, linkerRange)) { return linker; } } const message = `This application depends upon a library published using Angular version ${version}, which requires Angular version ${minVersion} or newer to work correctly. Consider upgrading your application to use a more recent version of Angular.`; if (this.unknownDeclarationVersionHandling === "error") { throw new Error(message); } else if (this.unknownDeclarationVersionHandling === "warn") { this.logger.warn(`${message} Attempting to continue using this version of Angular.`); } return linkerRanges[linkerRanges.length - 1].linker; } }; function getRange(comparator, versionStr) { const version = new semver2.SemVer(versionStr); version.prerelease = []; return new semver2.Range(`${comparator}${version.format()}`); } // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/file_linker.mjs var FileLinker = class { constructor(linkerEnvironment, sourceUrl, code) { this.linkerEnvironment = linkerEnvironment; this.emitScopes = /* @__PURE__ */ new Map(); this.linkerSelector = new PartialLinkerSelector(createLinkerMap(this.linkerEnvironment, sourceUrl, code), this.linkerEnvironment.logger, this.linkerEnvironment.options.unknownDeclarationVersionHandling); } isPartialDeclaration(calleeName) { return this.linkerSelector.supportsDeclaration(calleeName); } linkPartialDeclaration(declarationFn, args, declarationScope) { if (args.length !== 1) { throw new Error(`Invalid function call: It should have only a single object literal argument, but contained ${args.length}.`); } const metaObj = AstObject.parse(args[0], this.linkerEnvironment.host); const ngImport = metaObj.getNode("ngImport"); const emitScope = this.getEmitScope(ngImport, declarationScope); const minVersion = metaObj.getString("minVersion"); const version = metaObj.getString("version"); const linker = this.linkerSelector.getLinker(declarationFn, minVersion, version); const definition = linker.linkPartialDeclaration(emitScope.constantPool, metaObj, version); return emitScope.translateDefinition(definition); } getConstantStatements() { const results = []; for (const [constantScope, emitScope] of this.emitScopes.entries()) { const statements = emitScope.getConstantStatements(); results.push({ constantScope, statements }); } return results; } getEmitScope(ngImport, declarationScope) { const constantScope = declarationScope.getConstantScopeRef(ngImport); if (constantScope === null) { return new LocalEmitScope(ngImport, this.linkerEnvironment.translator, this.linkerEnvironment.factory); } if (!this.emitScopes.has(constantScope)) { this.emitScopes.set(constantScope, new EmitScope(ngImport, this.linkerEnvironment.translator, this.linkerEnvironment.factory)); } return this.emitScopes.get(constantScope); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/linker_options.mjs var DEFAULT_LINKER_OPTIONS = { sourceMapping: true, linkerJitMode: false, unknownDeclarationVersionHandling: "error" }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/translator.mjs var Translator = class { constructor(factory) { this.factory = factory; } translateExpression(expression, imports, options = {}) { return expression.visitExpression(new ExpressionTranslatorVisitor(this.factory, imports, options), new Context(false)); } translateStatement(statement, imports, options = {}) { return statement.visitStatement(new ExpressionTranslatorVisitor(this.factory, imports, options), new Context(true)); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/linker_environment.mjs var LinkerEnvironment = class { constructor(fileSystem, logger, host, factory, options) { this.fileSystem = fileSystem; this.logger = logger; this.host = host; this.factory = factory; this.options = options; this.translator = new Translator(this.factory); this.sourceFileLoader = this.options.sourceMapping ? new SourceFileLoader(this.fileSystem, this.logger, {}) : null; } static create(fileSystem, logger, host, factory, options) { var _a, _b, _c; return new LinkerEnvironment(fileSystem, logger, host, factory, { sourceMapping: (_a = options.sourceMapping) != null ? _a : DEFAULT_LINKER_OPTIONS.sourceMapping, linkerJitMode: (_b = options.linkerJitMode) != null ? _b : DEFAULT_LINKER_OPTIONS.linkerJitMode, unknownDeclarationVersionHandling: (_c = options.unknownDeclarationVersionHandling) != null ? _c : DEFAULT_LINKER_OPTIONS.unknownDeclarationVersionHandling }); } }; // bazel-out/k8-fastbuild/bin/packages/compiler-cli/linker/src/file_linker/needs_linking.mjs function needsLinking(path, source) { return declarationFunctions.some((fn) => source.includes(fn)); } export { FatalLinkerError, isFatalLinkerError, assert, FileLinker, DEFAULT_LINKER_OPTIONS, LinkerEnvironment, needsLinking }; /** * @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-ENSQEBQC.js.map