@angular/compiler 18.1.0-next.4 → 18.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/src/ml_parser/lexer.mjs +6 -3
- package/esm2022/src/render3/partial/class_metadata.mjs +2 -2
- package/esm2022/src/render3/partial/directive.mjs +1 -1
- package/esm2022/src/render3/partial/factory.mjs +1 -1
- package/esm2022/src/render3/partial/injectable.mjs +1 -1
- package/esm2022/src/render3/partial/injector.mjs +1 -1
- package/esm2022/src/render3/partial/ng_module.mjs +1 -1
- package/esm2022/src/render3/partial/pipe.mjs +1 -1
- package/esm2022/src/shadow_css.mjs +5 -5
- package/esm2022/src/template/pipeline/ir/src/variable.mjs +1 -1
- package/esm2022/src/template/pipeline/src/phases/generate_local_let_references.mjs +2 -1
- package/esm2022/src/template/pipeline/src/phases/generate_variables.mjs +4 -1
- package/esm2022/src/template/pipeline/src/phases/resolve_names.mjs +18 -2
- package/esm2022/src/version.mjs +1 -1
- package/fesm2022/compiler.mjs +40 -17
- package/fesm2022/compiler.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/package.json +2 -2
|
@@ -84,6 +84,7 @@ function getScopeForView(view, parent) {
|
|
|
84
84
|
kind: ir.SemanticVariableKind.Identifier,
|
|
85
85
|
name: null,
|
|
86
86
|
identifier,
|
|
87
|
+
local: false,
|
|
87
88
|
});
|
|
88
89
|
}
|
|
89
90
|
for (const op of view.create) {
|
|
@@ -104,6 +105,7 @@ function getScopeForView(view, parent) {
|
|
|
104
105
|
kind: ir.SemanticVariableKind.Identifier,
|
|
105
106
|
name: null,
|
|
106
107
|
identifier: op.localRefs[offset].name,
|
|
108
|
+
local: false,
|
|
107
109
|
},
|
|
108
110
|
});
|
|
109
111
|
}
|
|
@@ -116,6 +118,7 @@ function getScopeForView(view, parent) {
|
|
|
116
118
|
kind: ir.SemanticVariableKind.Identifier,
|
|
117
119
|
name: null,
|
|
118
120
|
identifier: op.declaredName,
|
|
121
|
+
local: false,
|
|
119
122
|
},
|
|
120
123
|
});
|
|
121
124
|
break;
|
|
@@ -164,4 +167,4 @@ function generateVariablesInScopeForView(view, scope, isListener) {
|
|
|
164
167
|
}
|
|
165
168
|
return newOps;
|
|
166
169
|
}
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate_variables.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/generate_variables.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as o from '../../../../output/output_ast';\nimport * as ir from '../../ir';\n\nimport type {ComponentCompilationJob, ViewCompilationUnit} from '../compilation';\n\n/**\n * Generate a preamble sequence for each view creation block and listener function which declares\n * any variables that be referenced in other operations in the block.\n *\n * Variables generated include:\n *   * a saved view context to be used to restore the current view in event listeners.\n *   * the context of the restored view within event listener handlers.\n *   * context variables from the current view as well as all parent views (including the root\n *     context if needed).\n *   * local references from elements within the current view and any lexical parents.\n *\n * Variables are generated here unconditionally, and may optimized away in future operations if it\n * turns out their values (and any side effects) are unused.\n */\nexport function generateVariables(job: ComponentCompilationJob): void {\n  recursivelyProcessView(job.root, /* there is no parent scope for the root view */ null);\n}\n\n/**\n * Process the given `ViewCompilation` and generate preambles for it and any listeners that it\n * declares.\n *\n * @param `parentScope` a scope extracted from the parent view which captures any variables which\n *     should be inherited by this view. `null` if the current view is the root view.\n */\nfunction recursivelyProcessView(view: ViewCompilationUnit, parentScope: Scope | null): void {\n  // Extract a `Scope` from this view.\n  const scope = getScopeForView(view, parentScope);\n\n  for (const op of view.create) {\n    switch (op.kind) {\n      case ir.OpKind.Template:\n        // Descend into child embedded views.\n        recursivelyProcessView(view.job.views.get(op.xref)!, scope);\n        break;\n      case ir.OpKind.Projection:\n        if (op.fallbackView !== null) {\n          recursivelyProcessView(view.job.views.get(op.fallbackView)!, scope);\n        }\n        break;\n      case ir.OpKind.RepeaterCreate:\n        // Descend into child embedded views.\n        recursivelyProcessView(view.job.views.get(op.xref)!, scope);\n        if (op.emptyView) {\n          recursivelyProcessView(view.job.views.get(op.emptyView)!, scope);\n        }\n        break;\n      case ir.OpKind.Listener:\n      case ir.OpKind.TwoWayListener:\n        // Prepend variables to listener handler functions.\n        op.handlerOps.prepend(generateVariablesInScopeForView(view, scope, true));\n        break;\n    }\n  }\n\n  view.update.prepend(generateVariablesInScopeForView(view, scope, false));\n}\n\n/**\n * Lexical scope of a view, including a reference to its parent view's scope, if any.\n */\ninterface Scope {\n  /**\n   * `XrefId` of the view to which this scope corresponds.\n   */\n  view: ir.XrefId;\n\n  viewContextVariable: ir.SemanticVariable;\n\n  contextVariables: Map<string, ir.SemanticVariable>;\n\n  aliases: Set<ir.AliasVariable>;\n\n  /**\n   * Local references collected from elements within the view.\n   */\n  references: Reference[];\n\n  /**\n   * `@let` declarations collected from the view.\n   */\n  letDeclarations: LetDeclaration[];\n\n  /**\n   * `Scope` of the parent view, if any.\n   */\n  parent: Scope | null;\n}\n\n/**\n * Information needed about a local reference collected from an element within a view.\n */\ninterface Reference {\n  /**\n   * Name given to the local reference variable within the template.\n   *\n   * This is not the name which will be used for the variable declaration in the generated\n   * template code.\n   */\n  name: string;\n\n  /**\n   * `XrefId` of the element-like node which this reference targets.\n   *\n   * The reference may be either to the element (or template) itself, or to a directive on it.\n   */\n  targetId: ir.XrefId;\n\n  targetSlot: ir.SlotHandle;\n\n  /**\n   * A generated offset of this reference among all the references on a specific element.\n   */\n  offset: number;\n\n  variable: ir.SemanticVariable;\n}\n\n/**\n * Information about `@let` declaration collected from a view.\n */\ninterface LetDeclaration {\n  /** `XrefId` of the `@let` declaration that the reference is pointing to. */\n  targetId: ir.XrefId;\n\n  /** Slot in which the declaration is stored. */\n  targetSlot: ir.SlotHandle;\n\n  /** Variable referring to the declaration. */\n  variable: ir.IdentifierVariable;\n}\n\n/**\n * Process a view and generate a `Scope` representing the variables available for reference within\n * that view.\n */\nfunction getScopeForView(view: ViewCompilationUnit, parent: Scope | null): Scope {\n  const scope: Scope = {\n    view: view.xref,\n    viewContextVariable: {\n      kind: ir.SemanticVariableKind.Context,\n      name: null,\n      view: view.xref,\n    },\n    contextVariables: new Map<string, ir.SemanticVariable>(),\n    aliases: view.aliases,\n    references: [],\n    letDeclarations: [],\n    parent,\n  };\n\n  for (const identifier of view.contextVariables.keys()) {\n    scope.contextVariables.set(identifier, {\n      kind: ir.SemanticVariableKind.Identifier,\n      name: null,\n      identifier,\n    });\n  }\n\n  for (const op of view.create) {\n    switch (op.kind) {\n      case ir.OpKind.ElementStart:\n      case ir.OpKind.Template:\n        if (!Array.isArray(op.localRefs)) {\n          throw new Error(`AssertionError: expected localRefs to be an array`);\n        }\n\n        // Record available local references from this element.\n        for (let offset = 0; offset < op.localRefs.length; offset++) {\n          scope.references.push({\n            name: op.localRefs[offset].name,\n            targetId: op.xref,\n            targetSlot: op.handle,\n            offset,\n            variable: {\n              kind: ir.SemanticVariableKind.Identifier,\n              name: null,\n              identifier: op.localRefs[offset].name,\n            },\n          });\n        }\n        break;\n\n      case ir.OpKind.DeclareLet:\n        scope.letDeclarations.push({\n          targetId: op.xref,\n          targetSlot: op.handle,\n          variable: {\n            kind: ir.SemanticVariableKind.Identifier,\n            name: null,\n            identifier: op.declaredName,\n          },\n        });\n        break;\n    }\n  }\n\n  return scope;\n}\n\n/**\n * Generate declarations for all variables that are in scope for a given view.\n *\n * This is a recursive process, as views inherit variables available from their parent view, which\n * itself may have inherited variables, etc.\n */\nfunction generateVariablesInScopeForView(\n  view: ViewCompilationUnit,\n  scope: Scope,\n  isListener: boolean,\n): ir.VariableOp<ir.UpdateOp>[] {\n  const newOps: ir.VariableOp<ir.UpdateOp>[] = [];\n\n  if (scope.view !== view.xref) {\n    // Before generating variables for a parent view, we need to switch to the context of the parent\n    // view with a `nextContext` expression. This context switching operation itself declares a\n    // variable, because the context of the view may be referenced directly.\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        scope.viewContextVariable,\n        new ir.NextContextExpr(),\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  // Add variables for all context variables available in this scope's view.\n  const scopeView = view.job.views.get(scope.view)!;\n  for (const [name, value] of scopeView.contextVariables) {\n    const context = new ir.ContextExpr(scope.view);\n    // We either read the context, or, if the variable is CTX_REF, use the context directly.\n    const variable = value === ir.CTX_REF ? context : new o.ReadPropExpr(context, value);\n    // Add the variable declaration.\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        scope.contextVariables.get(name)!,\n        variable,\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  for (const alias of scopeView.aliases) {\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        alias,\n        alias.expression.clone(),\n        ir.VariableFlags.AlwaysInline,\n      ),\n    );\n  }\n\n  // Add variables for all local references declared for elements in this scope.\n  for (const ref of scope.references) {\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        ref.variable,\n        new ir.ReferenceExpr(ref.targetId, ref.targetSlot, ref.offset),\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  if (scope.view !== view.xref || isListener) {\n    for (const decl of scope.letDeclarations) {\n      newOps.push(\n        ir.createVariableOp<ir.UpdateOp>(\n          view.job.allocateXrefId(),\n          decl.variable,\n          new ir.ContextLetReferenceExpr(decl.targetId, decl.targetSlot),\n          ir.VariableFlags.None,\n        ),\n      );\n    }\n  }\n\n  if (scope.parent !== null) {\n    // Recursively add variables from the parent scope.\n    newOps.push(...generateVariablesInScopeForView(view, scope.parent, false));\n  }\n  return newOps;\n}\n"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate_variables.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/generate_variables.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as o from '../../../../output/output_ast';\nimport * as ir from '../../ir';\n\nimport type {ComponentCompilationJob, ViewCompilationUnit} from '../compilation';\n\n/**\n * Generate a preamble sequence for each view creation block and listener function which declares\n * any variables that be referenced in other operations in the block.\n *\n * Variables generated include:\n *   * a saved view context to be used to restore the current view in event listeners.\n *   * the context of the restored view within event listener handlers.\n *   * context variables from the current view as well as all parent views (including the root\n *     context if needed).\n *   * local references from elements within the current view and any lexical parents.\n *\n * Variables are generated here unconditionally, and may optimized away in future operations if it\n * turns out their values (and any side effects) are unused.\n */\nexport function generateVariables(job: ComponentCompilationJob): void {\n  recursivelyProcessView(job.root, /* there is no parent scope for the root view */ null);\n}\n\n/**\n * Process the given `ViewCompilation` and generate preambles for it and any listeners that it\n * declares.\n *\n * @param `parentScope` a scope extracted from the parent view which captures any variables which\n *     should be inherited by this view. `null` if the current view is the root view.\n */\nfunction recursivelyProcessView(view: ViewCompilationUnit, parentScope: Scope | null): void {\n  // Extract a `Scope` from this view.\n  const scope = getScopeForView(view, parentScope);\n\n  for (const op of view.create) {\n    switch (op.kind) {\n      case ir.OpKind.Template:\n        // Descend into child embedded views.\n        recursivelyProcessView(view.job.views.get(op.xref)!, scope);\n        break;\n      case ir.OpKind.Projection:\n        if (op.fallbackView !== null) {\n          recursivelyProcessView(view.job.views.get(op.fallbackView)!, scope);\n        }\n        break;\n      case ir.OpKind.RepeaterCreate:\n        // Descend into child embedded views.\n        recursivelyProcessView(view.job.views.get(op.xref)!, scope);\n        if (op.emptyView) {\n          recursivelyProcessView(view.job.views.get(op.emptyView)!, scope);\n        }\n        break;\n      case ir.OpKind.Listener:\n      case ir.OpKind.TwoWayListener:\n        // Prepend variables to listener handler functions.\n        op.handlerOps.prepend(generateVariablesInScopeForView(view, scope, true));\n        break;\n    }\n  }\n\n  view.update.prepend(generateVariablesInScopeForView(view, scope, false));\n}\n\n/**\n * Lexical scope of a view, including a reference to its parent view's scope, if any.\n */\ninterface Scope {\n  /**\n   * `XrefId` of the view to which this scope corresponds.\n   */\n  view: ir.XrefId;\n\n  viewContextVariable: ir.SemanticVariable;\n\n  contextVariables: Map<string, ir.SemanticVariable>;\n\n  aliases: Set<ir.AliasVariable>;\n\n  /**\n   * Local references collected from elements within the view.\n   */\n  references: Reference[];\n\n  /**\n   * `@let` declarations collected from the view.\n   */\n  letDeclarations: LetDeclaration[];\n\n  /**\n   * `Scope` of the parent view, if any.\n   */\n  parent: Scope | null;\n}\n\n/**\n * Information needed about a local reference collected from an element within a view.\n */\ninterface Reference {\n  /**\n   * Name given to the local reference variable within the template.\n   *\n   * This is not the name which will be used for the variable declaration in the generated\n   * template code.\n   */\n  name: string;\n\n  /**\n   * `XrefId` of the element-like node which this reference targets.\n   *\n   * The reference may be either to the element (or template) itself, or to a directive on it.\n   */\n  targetId: ir.XrefId;\n\n  targetSlot: ir.SlotHandle;\n\n  /**\n   * A generated offset of this reference among all the references on a specific element.\n   */\n  offset: number;\n\n  variable: ir.SemanticVariable;\n}\n\n/**\n * Information about `@let` declaration collected from a view.\n */\ninterface LetDeclaration {\n  /** `XrefId` of the `@let` declaration that the reference is pointing to. */\n  targetId: ir.XrefId;\n\n  /** Slot in which the declaration is stored. */\n  targetSlot: ir.SlotHandle;\n\n  /** Variable referring to the declaration. */\n  variable: ir.IdentifierVariable;\n}\n\n/**\n * Process a view and generate a `Scope` representing the variables available for reference within\n * that view.\n */\nfunction getScopeForView(view: ViewCompilationUnit, parent: Scope | null): Scope {\n  const scope: Scope = {\n    view: view.xref,\n    viewContextVariable: {\n      kind: ir.SemanticVariableKind.Context,\n      name: null,\n      view: view.xref,\n    },\n    contextVariables: new Map<string, ir.SemanticVariable>(),\n    aliases: view.aliases,\n    references: [],\n    letDeclarations: [],\n    parent,\n  };\n\n  for (const identifier of view.contextVariables.keys()) {\n    scope.contextVariables.set(identifier, {\n      kind: ir.SemanticVariableKind.Identifier,\n      name: null,\n      identifier,\n      local: false,\n    });\n  }\n\n  for (const op of view.create) {\n    switch (op.kind) {\n      case ir.OpKind.ElementStart:\n      case ir.OpKind.Template:\n        if (!Array.isArray(op.localRefs)) {\n          throw new Error(`AssertionError: expected localRefs to be an array`);\n        }\n\n        // Record available local references from this element.\n        for (let offset = 0; offset < op.localRefs.length; offset++) {\n          scope.references.push({\n            name: op.localRefs[offset].name,\n            targetId: op.xref,\n            targetSlot: op.handle,\n            offset,\n            variable: {\n              kind: ir.SemanticVariableKind.Identifier,\n              name: null,\n              identifier: op.localRefs[offset].name,\n              local: false,\n            },\n          });\n        }\n        break;\n\n      case ir.OpKind.DeclareLet:\n        scope.letDeclarations.push({\n          targetId: op.xref,\n          targetSlot: op.handle,\n          variable: {\n            kind: ir.SemanticVariableKind.Identifier,\n            name: null,\n            identifier: op.declaredName,\n            local: false,\n          },\n        });\n        break;\n    }\n  }\n\n  return scope;\n}\n\n/**\n * Generate declarations for all variables that are in scope for a given view.\n *\n * This is a recursive process, as views inherit variables available from their parent view, which\n * itself may have inherited variables, etc.\n */\nfunction generateVariablesInScopeForView(\n  view: ViewCompilationUnit,\n  scope: Scope,\n  isListener: boolean,\n): ir.VariableOp<ir.UpdateOp>[] {\n  const newOps: ir.VariableOp<ir.UpdateOp>[] = [];\n\n  if (scope.view !== view.xref) {\n    // Before generating variables for a parent view, we need to switch to the context of the parent\n    // view with a `nextContext` expression. This context switching operation itself declares a\n    // variable, because the context of the view may be referenced directly.\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        scope.viewContextVariable,\n        new ir.NextContextExpr(),\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  // Add variables for all context variables available in this scope's view.\n  const scopeView = view.job.views.get(scope.view)!;\n  for (const [name, value] of scopeView.contextVariables) {\n    const context = new ir.ContextExpr(scope.view);\n    // We either read the context, or, if the variable is CTX_REF, use the context directly.\n    const variable = value === ir.CTX_REF ? context : new o.ReadPropExpr(context, value);\n    // Add the variable declaration.\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        scope.contextVariables.get(name)!,\n        variable,\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  for (const alias of scopeView.aliases) {\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        alias,\n        alias.expression.clone(),\n        ir.VariableFlags.AlwaysInline,\n      ),\n    );\n  }\n\n  // Add variables for all local references declared for elements in this scope.\n  for (const ref of scope.references) {\n    newOps.push(\n      ir.createVariableOp(\n        view.job.allocateXrefId(),\n        ref.variable,\n        new ir.ReferenceExpr(ref.targetId, ref.targetSlot, ref.offset),\n        ir.VariableFlags.None,\n      ),\n    );\n  }\n\n  if (scope.view !== view.xref || isListener) {\n    for (const decl of scope.letDeclarations) {\n      newOps.push(\n        ir.createVariableOp<ir.UpdateOp>(\n          view.job.allocateXrefId(),\n          decl.variable,\n          new ir.ContextLetReferenceExpr(decl.targetId, decl.targetSlot),\n          ir.VariableFlags.None,\n        ),\n      );\n    }\n  }\n\n  if (scope.parent !== null) {\n    // Recursively add variables from the parent scope.\n    newOps.push(...generateVariablesInScopeForView(view, scope.parent, false));\n  }\n  return newOps;\n}\n"]}
|
|
@@ -27,6 +27,8 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
27
27
|
// Since variables are generated in each view for the entire lexical scope (including any
|
|
28
28
|
// identifiers from parent templates) only local variables need be considered here.
|
|
29
29
|
const scope = new Map();
|
|
30
|
+
// Symbols defined within the current scope. They take precedence over ones defined outside.
|
|
31
|
+
const localDefinitions = new Map();
|
|
30
32
|
// First, step through the operations list and:
|
|
31
33
|
// 1) build up the `scope` mapping
|
|
32
34
|
// 2) recurse into any listener functions
|
|
@@ -35,6 +37,17 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
35
37
|
case ir.OpKind.Variable:
|
|
36
38
|
switch (op.variable.kind) {
|
|
37
39
|
case ir.SemanticVariableKind.Identifier:
|
|
40
|
+
if (op.variable.local) {
|
|
41
|
+
if (localDefinitions.has(op.variable.identifier)) {
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
localDefinitions.set(op.variable.identifier, op.xref);
|
|
45
|
+
}
|
|
46
|
+
else if (scope.has(op.variable.identifier)) {
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
scope.set(op.variable.identifier, op.xref);
|
|
50
|
+
break;
|
|
38
51
|
case ir.SemanticVariableKind.Alias:
|
|
39
52
|
// This variable represents some kind of identifier which can be used in the template.
|
|
40
53
|
if (scope.has(op.variable.identifier)) {
|
|
@@ -73,7 +86,10 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
73
86
|
// `expr` is a read of a name within the lexical scope of this view.
|
|
74
87
|
// Either that name is defined within the current view, or it represents a property from the
|
|
75
88
|
// main component context.
|
|
76
|
-
if (
|
|
89
|
+
if (localDefinitions.has(expr.name)) {
|
|
90
|
+
return new ir.ReadVariableExpr(localDefinitions.get(expr.name));
|
|
91
|
+
}
|
|
92
|
+
else if (scope.has(expr.name)) {
|
|
77
93
|
// This was a defined variable in the current scope.
|
|
78
94
|
return new ir.ReadVariableExpr(scope.get(expr.name));
|
|
79
95
|
}
|
|
@@ -105,4 +121,4 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
105
121
|
});
|
|
106
122
|
}
|
|
107
123
|
}
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolve_names.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/resolve_names.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as o from '../../../../output/output_ast';\nimport * as ir from '../../ir';\nimport {CompilationJob, CompilationUnit} from '../compilation';\n\n/**\n * Resolves lexical references in views (`ir.LexicalReadExpr`) to either a target variable or to\n * property reads on the top-level component context.\n *\n * Also matches `ir.RestoreViewExpr` expressions with the variables of their corresponding saved\n * views.\n */\nexport function resolveNames(job: CompilationJob): void {\n  for (const unit of job.units) {\n    processLexicalScope(unit, unit.create, null);\n    processLexicalScope(unit, unit.update, null);\n  }\n}\n\nfunction processLexicalScope(\n  unit: CompilationUnit,\n  ops: ir.OpList<ir.CreateOp> | ir.OpList<ir.UpdateOp>,\n  savedView: SavedView | null,\n): void {\n  // Maps names defined in the lexical scope of this template to the `ir.XrefId`s of the variable\n  // declarations which represent those values.\n  //\n  // Since variables are generated in each view for the entire lexical scope (including any\n  // identifiers from parent templates) only local variables need be considered here.\n  const scope = new Map<string, ir.XrefId>();\n\n  // First, step through the operations list and:\n  // 1) build up the `scope` mapping\n  // 2) recurse into any listener functions\n  for (const op of ops) {\n    switch (op.kind) {\n      case ir.OpKind.Variable:\n        switch (op.variable.kind) {\n          case ir.SemanticVariableKind.Identifier:\n          case ir.SemanticVariableKind.Alias:\n            // This variable represents some kind of identifier which can be used in the template.\n            if (scope.has(op.variable.identifier)) {\n              continue;\n            }\n            scope.set(op.variable.identifier, op.xref);\n            break;\n          case ir.SemanticVariableKind.SavedView:\n            // This variable represents a snapshot of the current view context, and can be used to\n            // restore that context within listener functions.\n            savedView = {\n              view: op.variable.view,\n              variable: op.xref,\n            };\n            break;\n        }\n        break;\n      case ir.OpKind.Listener:\n      case ir.OpKind.TwoWayListener:\n        // Listener functions have separate variable declarations, so process them as a separate\n        // lexical scope.\n        processLexicalScope(unit, op.handlerOps, savedView);\n        break;\n    }\n  }\n\n  // Next, use the `scope` mapping to match `ir.LexicalReadExpr` with defined names in the lexical\n  // scope. Also, look for `ir.RestoreViewExpr`s and match them with the snapshotted view context\n  // variable.\n  for (const op of ops) {\n    if (op.kind == ir.OpKind.Listener || op.kind === ir.OpKind.TwoWayListener) {\n      // Listeners were already processed above with their own scopes.\n      continue;\n    }\n    ir.transformExpressionsInOp(\n      op,\n      (expr) => {\n        if (expr instanceof ir.LexicalReadExpr) {\n          // `expr` is a read of a name within the lexical scope of this view.\n          // Either that name is defined within the current view, or it represents a property from the\n          // main component context.\n          if (scope.has(expr.name)) {\n            // This was a defined variable in the current scope.\n            return new ir.ReadVariableExpr(scope.get(expr.name)!);\n          } else {\n            // Reading from the component context.\n            return new o.ReadPropExpr(new ir.ContextExpr(unit.job.root.xref), expr.name);\n          }\n        } else if (expr instanceof ir.RestoreViewExpr && typeof expr.view === 'number') {\n          // `ir.RestoreViewExpr` happens in listener functions and restores a saved view from the\n          // parent creation list. We expect to find that we captured the `savedView` previously, and\n          // that it matches the expected view to be restored.\n          if (savedView === null || savedView.view !== expr.view) {\n            throw new Error(`AssertionError: no saved view ${expr.view} from view ${unit.xref}`);\n          }\n          expr.view = new ir.ReadVariableExpr(savedView.variable);\n          return expr;\n        } else {\n          return expr;\n        }\n      },\n      ir.VisitorContextFlag.None,\n    );\n  }\n\n  for (const op of ops) {\n    ir.visitExpressionsInOp(op, (expr) => {\n      if (expr instanceof ir.LexicalReadExpr) {\n        throw new Error(\n          `AssertionError: no lexical reads should remain, but found read of ${expr.name}`,\n        );\n      }\n    });\n  }\n}\n\n/**\n * Information about a `SavedView` variable.\n */\ninterface SavedView {\n  /**\n   * The view `ir.XrefId` which was saved into this variable.\n   */\n  view: ir.XrefId;\n\n  /**\n   * The `ir.XrefId` of the variable into which the view was saved.\n   */\n  variable: ir.XrefId;\n}\n"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolve_names.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler/src/template/pipeline/src/phases/resolve_names.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as o from '../../../../output/output_ast';\nimport * as ir from '../../ir';\nimport {CompilationJob, CompilationUnit} from '../compilation';\n\n/**\n * Resolves lexical references in views (`ir.LexicalReadExpr`) to either a target variable or to\n * property reads on the top-level component context.\n *\n * Also matches `ir.RestoreViewExpr` expressions with the variables of their corresponding saved\n * views.\n */\nexport function resolveNames(job: CompilationJob): void {\n  for (const unit of job.units) {\n    processLexicalScope(unit, unit.create, null);\n    processLexicalScope(unit, unit.update, null);\n  }\n}\n\nfunction processLexicalScope(\n  unit: CompilationUnit,\n  ops: ir.OpList<ir.CreateOp> | ir.OpList<ir.UpdateOp>,\n  savedView: SavedView | null,\n): void {\n  // Maps names defined in the lexical scope of this template to the `ir.XrefId`s of the variable\n  // declarations which represent those values.\n  //\n  // Since variables are generated in each view for the entire lexical scope (including any\n  // identifiers from parent templates) only local variables need be considered here.\n  const scope = new Map<string, ir.XrefId>();\n\n  // Symbols defined within the current scope. They take precedence over ones defined outside.\n  const localDefinitions = new Map<string, ir.XrefId>();\n\n  // First, step through the operations list and:\n  // 1) build up the `scope` mapping\n  // 2) recurse into any listener functions\n  for (const op of ops) {\n    switch (op.kind) {\n      case ir.OpKind.Variable:\n        switch (op.variable.kind) {\n          case ir.SemanticVariableKind.Identifier:\n            if (op.variable.local) {\n              if (localDefinitions.has(op.variable.identifier)) {\n                continue;\n              }\n              localDefinitions.set(op.variable.identifier, op.xref);\n            } else if (scope.has(op.variable.identifier)) {\n              continue;\n            }\n            scope.set(op.variable.identifier, op.xref);\n            break;\n          case ir.SemanticVariableKind.Alias:\n            // This variable represents some kind of identifier which can be used in the template.\n            if (scope.has(op.variable.identifier)) {\n              continue;\n            }\n            scope.set(op.variable.identifier, op.xref);\n            break;\n          case ir.SemanticVariableKind.SavedView:\n            // This variable represents a snapshot of the current view context, and can be used to\n            // restore that context within listener functions.\n            savedView = {\n              view: op.variable.view,\n              variable: op.xref,\n            };\n            break;\n        }\n        break;\n      case ir.OpKind.Listener:\n      case ir.OpKind.TwoWayListener:\n        // Listener functions have separate variable declarations, so process them as a separate\n        // lexical scope.\n        processLexicalScope(unit, op.handlerOps, savedView);\n        break;\n    }\n  }\n\n  // Next, use the `scope` mapping to match `ir.LexicalReadExpr` with defined names in the lexical\n  // scope. Also, look for `ir.RestoreViewExpr`s and match them with the snapshotted view context\n  // variable.\n  for (const op of ops) {\n    if (op.kind == ir.OpKind.Listener || op.kind === ir.OpKind.TwoWayListener) {\n      // Listeners were already processed above with their own scopes.\n      continue;\n    }\n    ir.transformExpressionsInOp(\n      op,\n      (expr) => {\n        if (expr instanceof ir.LexicalReadExpr) {\n          // `expr` is a read of a name within the lexical scope of this view.\n          // Either that name is defined within the current view, or it represents a property from the\n          // main component context.\n          if (localDefinitions.has(expr.name)) {\n            return new ir.ReadVariableExpr(localDefinitions.get(expr.name)!);\n          } else if (scope.has(expr.name)) {\n            // This was a defined variable in the current scope.\n            return new ir.ReadVariableExpr(scope.get(expr.name)!);\n          } else {\n            // Reading from the component context.\n            return new o.ReadPropExpr(new ir.ContextExpr(unit.job.root.xref), expr.name);\n          }\n        } else if (expr instanceof ir.RestoreViewExpr && typeof expr.view === 'number') {\n          // `ir.RestoreViewExpr` happens in listener functions and restores a saved view from the\n          // parent creation list. We expect to find that we captured the `savedView` previously, and\n          // that it matches the expected view to be restored.\n          if (savedView === null || savedView.view !== expr.view) {\n            throw new Error(`AssertionError: no saved view ${expr.view} from view ${unit.xref}`);\n          }\n          expr.view = new ir.ReadVariableExpr(savedView.variable);\n          return expr;\n        } else {\n          return expr;\n        }\n      },\n      ir.VisitorContextFlag.None,\n    );\n  }\n\n  for (const op of ops) {\n    ir.visitExpressionsInOp(op, (expr) => {\n      if (expr instanceof ir.LexicalReadExpr) {\n        throw new Error(\n          `AssertionError: no lexical reads should remain, but found read of ${expr.name}`,\n        );\n      }\n    });\n  }\n}\n\n/**\n * Information about a `SavedView` variable.\n */\ninterface SavedView {\n  /**\n   * The view `ir.XrefId` which was saved into this variable.\n   */\n  view: ir.XrefId;\n\n  /**\n   * The `ir.XrefId` of the variable into which the view was saved.\n   */\n  variable: ir.XrefId;\n}\n"]}
|
package/esm2022/src/version.mjs
CHANGED
|
@@ -11,5 +11,5 @@
|
|
|
11
11
|
* Entry point for all public APIs of the compiler package.
|
|
12
12
|
*/
|
|
13
13
|
import { Version } from './util';
|
|
14
|
-
export const VERSION = new Version('18.1.0
|
|
14
|
+
export const VERSION = new Version('18.1.0');
|
|
15
15
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVIOzs7O0dBSUc7QUFFSCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sUUFBUSxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBjb21waWxlciBwYWNrYWdlLlxuICovXG5cbmltcG9ydCB7VmVyc2lvbn0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
|
package/fesm2022/compiler.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v18.1.0
|
|
2
|
+
* @license Angular v18.1.0
|
|
3
3
|
* (c) 2010-2024 Google LLC. https://angular.io/
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -7252,8 +7252,8 @@ class ShadowCss {
|
|
|
7252
7252
|
* animation declaration (with possibly multiple animation definitions)
|
|
7253
7253
|
*
|
|
7254
7254
|
* The regular expression can be divided in three parts
|
|
7255
|
-
* - (^|\s
|
|
7256
|
-
*
|
|
7255
|
+
* - (^|\s+|,)
|
|
7256
|
+
* captures how many (if any) leading whitespaces are present or a comma
|
|
7257
7257
|
* - (?:(?:(['"])((?:\\\\|\\\2|(?!\2).)+)\2)|(-?[A-Za-z][\w\-]*))
|
|
7258
7258
|
* captures two different possible keyframes, ones which are quoted or ones which are valid css
|
|
7259
7259
|
* idents (custom properties excluded)
|
|
@@ -7261,7 +7261,7 @@ class ShadowCss {
|
|
|
7261
7261
|
* simply matches the end of the possible keyframe, valid endings are: a comma, a space, a
|
|
7262
7262
|
* semicolon or the end of the string
|
|
7263
7263
|
*/
|
|
7264
|
-
this._animationDeclarationKeyframesRe = /(^|\s
|
|
7264
|
+
this._animationDeclarationKeyframesRe = /(^|\s+|,)(?:(?:(['"])((?:\\\\|\\\2|(?!\2).)+)\2)|(-?[A-Za-z][\w\-]*))(?=[,\s]|$)/g;
|
|
7265
7265
|
}
|
|
7266
7266
|
/*
|
|
7267
7267
|
* Shim some cssText with the given selector. Returns cssText that can be included in the document
|
|
@@ -7418,7 +7418,7 @@ class ShadowCss {
|
|
|
7418
7418
|
* @returns the updated css rule.
|
|
7419
7419
|
**/
|
|
7420
7420
|
_scopeAnimationRule(rule, scopeSelector, unscopedKeyframesSet) {
|
|
7421
|
-
let content = rule.content.replace(/((?:^|\s+|;)(?:-webkit-)?animation
|
|
7421
|
+
let content = rule.content.replace(/((?:^|\s+|;)(?:-webkit-)?animation\s*:\s*),*([^;]+)/g, (_, start, animationDeclarations) => start +
|
|
7422
7422
|
animationDeclarations.replace(this._animationDeclarationKeyframesRe, (original, leadingSpaces, quote = '', quotedName, nonQuotedName) => {
|
|
7423
7423
|
if (quotedName) {
|
|
7424
7424
|
return `${leadingSpaces}${this._scopeAnimationKeyframe(`${quote}${quotedName}${quote}`, scopeSelector, unscopedKeyframesSet)}`;
|
|
@@ -12528,6 +12528,7 @@ function getScopeForView(view, parent) {
|
|
|
12528
12528
|
kind: SemanticVariableKind.Identifier,
|
|
12529
12529
|
name: null,
|
|
12530
12530
|
identifier,
|
|
12531
|
+
local: false,
|
|
12531
12532
|
});
|
|
12532
12533
|
}
|
|
12533
12534
|
for (const op of view.create) {
|
|
@@ -12548,6 +12549,7 @@ function getScopeForView(view, parent) {
|
|
|
12548
12549
|
kind: SemanticVariableKind.Identifier,
|
|
12549
12550
|
name: null,
|
|
12550
12551
|
identifier: op.localRefs[offset].name,
|
|
12552
|
+
local: false,
|
|
12551
12553
|
},
|
|
12552
12554
|
});
|
|
12553
12555
|
}
|
|
@@ -12560,6 +12562,7 @@ function getScopeForView(view, parent) {
|
|
|
12560
12562
|
kind: SemanticVariableKind.Identifier,
|
|
12561
12563
|
name: null,
|
|
12562
12564
|
identifier: op.declaredName,
|
|
12565
|
+
local: false,
|
|
12563
12566
|
},
|
|
12564
12567
|
});
|
|
12565
12568
|
break;
|
|
@@ -18008,8 +18011,11 @@ class _Tokenizer {
|
|
|
18008
18011
|
const nameCursor = this._cursor.clone();
|
|
18009
18012
|
let allowDigit = false;
|
|
18010
18013
|
this._attemptCharCodeUntilFn((code) => {
|
|
18011
|
-
|
|
18012
|
-
|
|
18014
|
+
if (isAsciiLetter(code) ||
|
|
18015
|
+
code == $$ ||
|
|
18016
|
+
code === $_ ||
|
|
18017
|
+
// `@let` names can't start with a digit, but digits are valid anywhere else in the name.
|
|
18018
|
+
(allowDigit && isDigit(code))) {
|
|
18013
18019
|
allowDigit = true;
|
|
18014
18020
|
return false;
|
|
18015
18021
|
}
|
|
@@ -22714,6 +22720,8 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
22714
22720
|
// Since variables are generated in each view for the entire lexical scope (including any
|
|
22715
22721
|
// identifiers from parent templates) only local variables need be considered here.
|
|
22716
22722
|
const scope = new Map();
|
|
22723
|
+
// Symbols defined within the current scope. They take precedence over ones defined outside.
|
|
22724
|
+
const localDefinitions = new Map();
|
|
22717
22725
|
// First, step through the operations list and:
|
|
22718
22726
|
// 1) build up the `scope` mapping
|
|
22719
22727
|
// 2) recurse into any listener functions
|
|
@@ -22722,6 +22730,17 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
22722
22730
|
case OpKind.Variable:
|
|
22723
22731
|
switch (op.variable.kind) {
|
|
22724
22732
|
case SemanticVariableKind.Identifier:
|
|
22733
|
+
if (op.variable.local) {
|
|
22734
|
+
if (localDefinitions.has(op.variable.identifier)) {
|
|
22735
|
+
continue;
|
|
22736
|
+
}
|
|
22737
|
+
localDefinitions.set(op.variable.identifier, op.xref);
|
|
22738
|
+
}
|
|
22739
|
+
else if (scope.has(op.variable.identifier)) {
|
|
22740
|
+
continue;
|
|
22741
|
+
}
|
|
22742
|
+
scope.set(op.variable.identifier, op.xref);
|
|
22743
|
+
break;
|
|
22725
22744
|
case SemanticVariableKind.Alias:
|
|
22726
22745
|
// This variable represents some kind of identifier which can be used in the template.
|
|
22727
22746
|
if (scope.has(op.variable.identifier)) {
|
|
@@ -22760,7 +22779,10 @@ function processLexicalScope(unit, ops, savedView) {
|
|
|
22760
22779
|
// `expr` is a read of a name within the lexical scope of this view.
|
|
22761
22780
|
// Either that name is defined within the current view, or it represents a property from the
|
|
22762
22781
|
// main component context.
|
|
22763
|
-
if (
|
|
22782
|
+
if (localDefinitions.has(expr.name)) {
|
|
22783
|
+
return new ReadVariableExpr(localDefinitions.get(expr.name));
|
|
22784
|
+
}
|
|
22785
|
+
else if (scope.has(expr.name)) {
|
|
22764
22786
|
// This was a defined variable in the current scope.
|
|
22765
22787
|
return new ReadVariableExpr(scope.get(expr.name));
|
|
22766
22788
|
}
|
|
@@ -23971,6 +23993,7 @@ function generateLocalLetReferences(job) {
|
|
|
23971
23993
|
kind: SemanticVariableKind.Identifier,
|
|
23972
23994
|
name: null,
|
|
23973
23995
|
identifier: op.declaredName,
|
|
23996
|
+
local: true,
|
|
23974
23997
|
};
|
|
23975
23998
|
OpList.replace(op, createVariableOp(job.allocateXrefId(), variable, new StoreLetExpr(op.target, op.value, op.sourceSpan), VariableFlags.None));
|
|
23976
23999
|
}
|
|
@@ -29498,7 +29521,7 @@ function publishFacade(global) {
|
|
|
29498
29521
|
* @description
|
|
29499
29522
|
* Entry point for all public APIs of the compiler package.
|
|
29500
29523
|
*/
|
|
29501
|
-
const VERSION = new Version('18.1.0
|
|
29524
|
+
const VERSION = new Version('18.1.0');
|
|
29502
29525
|
|
|
29503
29526
|
class CompilerConfig {
|
|
29504
29527
|
constructor({ defaultEncapsulation = ViewEncapsulation.Emulated, preserveWhitespaces, strictInjectionParameters, } = {}) {
|
|
@@ -31136,7 +31159,7 @@ const MINIMUM_PARTIAL_LINKER_DEFER_SUPPORT_VERSION = '18.0.0';
|
|
|
31136
31159
|
function compileDeclareClassMetadata(metadata) {
|
|
31137
31160
|
const definitionMap = new DefinitionMap();
|
|
31138
31161
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$5));
|
|
31139
|
-
definitionMap.set('version', literal('18.1.0
|
|
31162
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31140
31163
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31141
31164
|
definitionMap.set('type', metadata.type);
|
|
31142
31165
|
definitionMap.set('decorators', metadata.decorators);
|
|
@@ -31154,7 +31177,7 @@ function compileComponentDeclareClassMetadata(metadata, dependencies) {
|
|
|
31154
31177
|
callbackReturnDefinitionMap.set('ctorParameters', metadata.ctorParameters ?? literal(null));
|
|
31155
31178
|
callbackReturnDefinitionMap.set('propDecorators', metadata.propDecorators ?? literal(null));
|
|
31156
31179
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_DEFER_SUPPORT_VERSION));
|
|
31157
|
-
definitionMap.set('version', literal('18.1.0
|
|
31180
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31158
31181
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31159
31182
|
definitionMap.set('type', metadata.type);
|
|
31160
31183
|
definitionMap.set('resolveDeferredDeps', compileComponentMetadataAsyncResolver(dependencies));
|
|
@@ -31249,7 +31272,7 @@ function createDirectiveDefinitionMap(meta) {
|
|
|
31249
31272
|
const definitionMap = new DefinitionMap();
|
|
31250
31273
|
const minVersion = getMinimumVersionForPartialOutput(meta);
|
|
31251
31274
|
definitionMap.set('minVersion', literal(minVersion));
|
|
31252
|
-
definitionMap.set('version', literal('18.1.0
|
|
31275
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31253
31276
|
// e.g. `type: MyDirective`
|
|
31254
31277
|
definitionMap.set('type', meta.type.value);
|
|
31255
31278
|
if (meta.isStandalone) {
|
|
@@ -31671,7 +31694,7 @@ const MINIMUM_PARTIAL_LINKER_VERSION$4 = '12.0.0';
|
|
|
31671
31694
|
function compileDeclareFactoryFunction(meta) {
|
|
31672
31695
|
const definitionMap = new DefinitionMap();
|
|
31673
31696
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$4));
|
|
31674
|
-
definitionMap.set('version', literal('18.1.0
|
|
31697
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31675
31698
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31676
31699
|
definitionMap.set('type', meta.type.value);
|
|
31677
31700
|
definitionMap.set('deps', compileDependencies(meta.deps));
|
|
@@ -31706,7 +31729,7 @@ function compileDeclareInjectableFromMetadata(meta) {
|
|
|
31706
31729
|
function createInjectableDefinitionMap(meta) {
|
|
31707
31730
|
const definitionMap = new DefinitionMap();
|
|
31708
31731
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$3));
|
|
31709
|
-
definitionMap.set('version', literal('18.1.0
|
|
31732
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31710
31733
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31711
31734
|
definitionMap.set('type', meta.type.value);
|
|
31712
31735
|
// Only generate providedIn property if it has a non-null value
|
|
@@ -31757,7 +31780,7 @@ function compileDeclareInjectorFromMetadata(meta) {
|
|
|
31757
31780
|
function createInjectorDefinitionMap(meta) {
|
|
31758
31781
|
const definitionMap = new DefinitionMap();
|
|
31759
31782
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$2));
|
|
31760
|
-
definitionMap.set('version', literal('18.1.0
|
|
31783
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31761
31784
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31762
31785
|
definitionMap.set('type', meta.type.value);
|
|
31763
31786
|
definitionMap.set('providers', meta.providers);
|
|
@@ -31790,7 +31813,7 @@ function createNgModuleDefinitionMap(meta) {
|
|
|
31790
31813
|
throw new Error('Invalid path! Local compilation mode should not get into the partial compilation path');
|
|
31791
31814
|
}
|
|
31792
31815
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION$1));
|
|
31793
|
-
definitionMap.set('version', literal('18.1.0
|
|
31816
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31794
31817
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31795
31818
|
definitionMap.set('type', meta.type.value);
|
|
31796
31819
|
// We only generate the keys in the metadata if the arrays contain values.
|
|
@@ -31841,7 +31864,7 @@ function compileDeclarePipeFromMetadata(meta) {
|
|
|
31841
31864
|
function createPipeDefinitionMap(meta) {
|
|
31842
31865
|
const definitionMap = new DefinitionMap();
|
|
31843
31866
|
definitionMap.set('minVersion', literal(MINIMUM_PARTIAL_LINKER_VERSION));
|
|
31844
|
-
definitionMap.set('version', literal('18.1.0
|
|
31867
|
+
definitionMap.set('version', literal('18.1.0'));
|
|
31845
31868
|
definitionMap.set('ngImport', importExpr(Identifiers.core));
|
|
31846
31869
|
// e.g. `type: MyPipe`
|
|
31847
31870
|
definitionMap.set('type', meta.type.value);
|