UNPKG

36.3 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google Inc. All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8import * as tslib_1 from "tslib";
9import * as o from './output/output_ast';
10import { error } from './util';
11var CONSTANT_PREFIX = '_c';
12/**
13 * Context to use when producing a key.
14 *
15 * This ensures we see the constant not the reference variable when producing
16 * a key.
17 */
18var KEY_CONTEXT = {};
19/**
20 * A node that is a place-holder that allows the node to be replaced when the actual
21 * node is known.
22 *
23 * This allows the constant pool to change an expression from a direct reference to
24 * a constant to a shared constant. It returns a fix-up node that is later allowed to
25 * change the referenced expression.
26 */
27var FixupExpression = /** @class */ (function (_super) {
28 tslib_1.__extends(FixupExpression, _super);
29 function FixupExpression(resolved) {
30 var _this = _super.call(this, resolved.type) || this;
31 _this.resolved = resolved;
32 _this.original = resolved;
33 return _this;
34 }
35 FixupExpression.prototype.visitExpression = function (visitor, context) {
36 if (context === KEY_CONTEXT) {
37 // When producing a key we want to traverse the constant not the
38 // variable used to refer to it.
39 return this.original.visitExpression(visitor, context);
40 }
41 else {
42 return this.resolved.visitExpression(visitor, context);
43 }
44 };
45 FixupExpression.prototype.isEquivalent = function (e) {
46 return e instanceof FixupExpression && this.resolved.isEquivalent(e.resolved);
47 };
48 FixupExpression.prototype.isConstant = function () { return true; };
49 FixupExpression.prototype.fixup = function (expression) {
50 this.resolved = expression;
51 this.shared = true;
52 };
53 return FixupExpression;
54}(o.Expression));
55/**
56 * A constant pool allows a code emitter to share constant in an output context.
57 *
58 * The constant pool also supports sharing access to ivy definitions references.
59 */
60var ConstantPool = /** @class */ (function () {
61 function ConstantPool() {
62 this.statements = [];
63 this.literals = new Map();
64 this.literalFactories = new Map();
65 this.injectorDefinitions = new Map();
66 this.directiveDefinitions = new Map();
67 this.componentDefinitions = new Map();
68 this.pipeDefinitions = new Map();
69 this.nextNameIndex = 0;
70 }
71 ConstantPool.prototype.getConstLiteral = function (literal, forceShared) {
72 if (literal instanceof o.LiteralExpr || literal instanceof FixupExpression) {
73 // Do no put simple literals into the constant pool or try to produce a constant for a
74 // reference to a constant.
75 return literal;
76 }
77 var key = this.keyOf(literal);
78 var fixup = this.literals.get(key);
79 var newValue = false;
80 if (!fixup) {
81 fixup = new FixupExpression(literal);
82 this.literals.set(key, fixup);
83 newValue = true;
84 }
85 if ((!newValue && !fixup.shared) || (newValue && forceShared)) {
86 // Replace the expression with a variable
87 var name_1 = this.freshName();
88 this.statements.push(o.variable(name_1).set(literal).toDeclStmt(o.INFERRED_TYPE, [o.StmtModifier.Final]));
89 fixup.fixup(o.variable(name_1));
90 }
91 return fixup;
92 };
93 ConstantPool.prototype.getDefinition = function (type, kind, ctx, forceShared) {
94 if (forceShared === void 0) { forceShared = false; }
95 var definitions = this.definitionsOf(kind);
96 var fixup = definitions.get(type);
97 var newValue = false;
98 if (!fixup) {
99 var property = this.propertyNameOf(kind);
100 fixup = new FixupExpression(ctx.importExpr(type).prop(property));
101 definitions.set(type, fixup);
102 newValue = true;
103 }
104 if ((!newValue && !fixup.shared) || (newValue && forceShared)) {
105 var name_2 = this.freshName();
106 this.statements.push(o.variable(name_2).set(fixup.resolved).toDeclStmt(o.INFERRED_TYPE, [o.StmtModifier.Final]));
107 fixup.fixup(o.variable(name_2));
108 }
109 return fixup;
110 };
111 ConstantPool.prototype.getLiteralFactory = function (literal) {
112 // Create a pure function that builds an array of a mix of constant and variable expressions
113 if (literal instanceof o.LiteralArrayExpr) {
114 var argumentsForKey = literal.entries.map(function (e) { return e.isConstant() ? e : o.literal(null); });
115 var key = this.keyOf(o.literalArr(argumentsForKey));
116 return this._getLiteralFactory(key, literal.entries, function (entries) { return o.literalArr(entries); });
117 }
118 else {
119 var expressionForKey = o.literalMap(literal.entries.map(function (e) { return ({
120 key: e.key,
121 value: e.value.isConstant() ? e.value : o.literal(null),
122 quoted: e.quoted
123 }); }));
124 var key = this.keyOf(expressionForKey);
125 return this._getLiteralFactory(key, literal.entries.map(function (e) { return e.value; }), function (entries) { return o.literalMap(entries.map(function (value, index) { return ({
126 key: literal.entries[index].key,
127 value: value,
128 quoted: literal.entries[index].quoted
129 }); })); });
130 }
131 };
132 ConstantPool.prototype._getLiteralFactory = function (key, values, resultMap) {
133 var _this = this;
134 var literalFactory = this.literalFactories.get(key);
135 var literalFactoryArguments = values.filter((function (e) { return !e.isConstant(); }));
136 if (!literalFactory) {
137 var resultExpressions = values.map(function (e, index) { return e.isConstant() ? _this.getConstLiteral(e, true) : o.variable("a" + index); });
138 var parameters = resultExpressions.filter(isVariable).map(function (e) { return new o.FnParam(e.name, o.DYNAMIC_TYPE); });
139 var pureFunctionDeclaration = o.fn(parameters, [new o.ReturnStatement(resultMap(resultExpressions))], o.INFERRED_TYPE);
140 var name_3 = this.freshName();
141 this.statements.push(o.variable(name_3).set(pureFunctionDeclaration).toDeclStmt(o.INFERRED_TYPE, [
142 o.StmtModifier.Final
143 ]));
144 literalFactory = o.variable(name_3);
145 this.literalFactories.set(key, literalFactory);
146 }
147 return { literalFactory: literalFactory, literalFactoryArguments: literalFactoryArguments };
148 };
149 /**
150 * Produce a unique name.
151 *
152 * The name might be unique among different prefixes if any of the prefixes end in
153 * a digit so the prefix should be a constant string (not based on user input) and
154 * must not end in a digit.
155 */
156 ConstantPool.prototype.uniqueName = function (prefix) { return "" + prefix + this.nextNameIndex++; };
157 ConstantPool.prototype.definitionsOf = function (kind) {
158 switch (kind) {
159 case 2 /* Component */:
160 return this.componentDefinitions;
161 case 1 /* Directive */:
162 return this.directiveDefinitions;
163 case 0 /* Injector */:
164 return this.injectorDefinitions;
165 case 3 /* Pipe */:
166 return this.pipeDefinitions;
167 }
168 error("Unknown definition kind " + kind);
169 return this.componentDefinitions;
170 };
171 ConstantPool.prototype.propertyNameOf = function (kind) {
172 switch (kind) {
173 case 2 /* Component */:
174 return 'ngComponentDef';
175 case 1 /* Directive */:
176 return 'ngDirectiveDef';
177 case 0 /* Injector */:
178 return 'ngInjectorDef';
179 case 3 /* Pipe */:
180 return 'ngPipeDef';
181 }
182 error("Unknown definition kind " + kind);
183 return '<unknown>';
184 };
185 ConstantPool.prototype.freshName = function () { return this.uniqueName(CONSTANT_PREFIX); };
186 ConstantPool.prototype.keyOf = function (expression) {
187 return expression.visitExpression(new KeyVisitor(), KEY_CONTEXT);
188 };
189 return ConstantPool;
190}());
191export { ConstantPool };
192/**
193 * Visitor used to determine if 2 expressions are equivalent and can be shared in the
194 * `ConstantPool`.
195 *
196 * When the id (string) generated by the visitor is equal, expressions are considered equivalent.
197 */
198var KeyVisitor = /** @class */ (function () {
199 function KeyVisitor() {
200 this.visitWrappedNodeExpr = invalid;
201 this.visitWriteVarExpr = invalid;
202 this.visitWriteKeyExpr = invalid;
203 this.visitWritePropExpr = invalid;
204 this.visitInvokeMethodExpr = invalid;
205 this.visitInvokeFunctionExpr = invalid;
206 this.visitInstantiateExpr = invalid;
207 this.visitConditionalExpr = invalid;
208 this.visitNotExpr = invalid;
209 this.visitAssertNotNullExpr = invalid;
210 this.visitCastExpr = invalid;
211 this.visitFunctionExpr = invalid;
212 this.visitBinaryOperatorExpr = invalid;
213 this.visitReadPropExpr = invalid;
214 this.visitReadKeyExpr = invalid;
215 this.visitCommaExpr = invalid;
216 }
217 KeyVisitor.prototype.visitLiteralExpr = function (ast) {
218 return "" + (typeof ast.value === 'string' ? '"' + ast.value + '"' : ast.value);
219 };
220 KeyVisitor.prototype.visitLiteralArrayExpr = function (ast, context) {
221 var _this = this;
222 return "[" + ast.entries.map(function (entry) { return entry.visitExpression(_this, context); }).join(',') + "]";
223 };
224 KeyVisitor.prototype.visitLiteralMapExpr = function (ast, context) {
225 var _this = this;
226 var mapKey = function (entry) {
227 var quote = entry.quoted ? '"' : '';
228 return "" + quote + entry.key + quote;
229 };
230 var mapEntry = function (entry) {
231 return mapKey(entry) + ":" + entry.value.visitExpression(_this, context);
232 };
233 return "{" + ast.entries.map(mapEntry).join(',');
234 };
235 KeyVisitor.prototype.visitExternalExpr = function (ast) {
236 return ast.value.moduleName ? "EX:" + ast.value.moduleName + ":" + ast.value.name :
237 "EX:" + ast.value.runtime.name;
238 };
239 KeyVisitor.prototype.visitReadVarExpr = function (node) { return "VAR:" + node.name; };
240 KeyVisitor.prototype.visitTypeofExpr = function (node, context) {
241 return "TYPEOF:" + node.expr.visitExpression(this, context);
242 };
243 return KeyVisitor;
244}());
245function invalid(arg) {
246 throw new Error("Invalid state: Visitor " + this.constructor.name + " doesn't handle " + arg.constructor.name);
247}
248function isVariable(e) {
249 return e instanceof o.ReadVarExpr;
250}
251//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constant_pool.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/constant_pool.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {OutputContext, error} from './util';\n\nconst CONSTANT_PREFIX = '_c';\n\nexport const enum DefinitionKind {Injector, Directive, Component, Pipe}\n\n/**\n * Context to use when producing a key.\n *\n * This ensures we see the constant not the reference variable when producing\n * a key.\n */\nconst KEY_CONTEXT = {};\n\n/**\n * A node that is a place-holder that allows the node to be replaced when the actual\n * node is known.\n *\n * This allows the constant pool to change an expression from a direct reference to\n * a constant to a shared constant. It returns a fix-up node that is later allowed to\n * change the referenced expression.\n */\nclass FixupExpression extends o.Expression {\n  private original: o.Expression;\n\n  // TODO(issue/24571): remove '!'.\n  shared !: boolean;\n\n  constructor(public resolved: o.Expression) {\n    super(resolved.type);\n    this.original = resolved;\n  }\n\n  visitExpression(visitor: o.ExpressionVisitor, context: any): any {\n    if (context === KEY_CONTEXT) {\n      // When producing a key we want to traverse the constant not the\n      // variable used to refer to it.\n      return this.original.visitExpression(visitor, context);\n    } else {\n      return this.resolved.visitExpression(visitor, context);\n    }\n  }\n\n  isEquivalent(e: o.Expression): boolean {\n    return e instanceof FixupExpression && this.resolved.isEquivalent(e.resolved);\n  }\n\n  isConstant() { return true; }\n\n  fixup(expression: o.Expression) {\n    this.resolved = expression;\n    this.shared = true;\n  }\n}\n\n/**\n * A constant pool allows a code emitter to share constant in an output context.\n *\n * The constant pool also supports sharing access to ivy definitions references.\n */\nexport class ConstantPool {\n  statements: o.Statement[] = [];\n  private literals = new Map<string, FixupExpression>();\n  private literalFactories = new Map<string, o.Expression>();\n  private injectorDefinitions = new Map<any, FixupExpression>();\n  private directiveDefinitions = new Map<any, FixupExpression>();\n  private componentDefinitions = new Map<any, FixupExpression>();\n  private pipeDefinitions = new Map<any, FixupExpression>();\n\n  private nextNameIndex = 0;\n\n  getConstLiteral(literal: o.Expression, forceShared?: boolean): o.Expression {\n    if (literal instanceof o.LiteralExpr || literal instanceof FixupExpression) {\n      // Do no put simple literals into the constant pool or try to produce a constant for a\n      // reference to a constant.\n      return literal;\n    }\n    const key = this.keyOf(literal);\n    let fixup = this.literals.get(key);\n    let newValue = false;\n    if (!fixup) {\n      fixup = new FixupExpression(literal);\n      this.literals.set(key, fixup);\n      newValue = true;\n    }\n\n    if ((!newValue && !fixup.shared) || (newValue && forceShared)) {\n      // Replace the expression with a variable\n      const name = this.freshName();\n      this.statements.push(\n          o.variable(name).set(literal).toDeclStmt(o.INFERRED_TYPE, [o.StmtModifier.Final]));\n      fixup.fixup(o.variable(name));\n    }\n\n    return fixup;\n  }\n\n  getDefinition(type: any, kind: DefinitionKind, ctx: OutputContext, forceShared: boolean = false):\n      o.Expression {\n    const definitions = this.definitionsOf(kind);\n    let fixup = definitions.get(type);\n    let newValue = false;\n    if (!fixup) {\n      const property = this.propertyNameOf(kind);\n      fixup = new FixupExpression(ctx.importExpr(type).prop(property));\n      definitions.set(type, fixup);\n      newValue = true;\n    }\n\n    if ((!newValue && !fixup.shared) || (newValue && forceShared)) {\n      const name = this.freshName();\n      this.statements.push(\n          o.variable(name).set(fixup.resolved).toDeclStmt(o.INFERRED_TYPE, [o.StmtModifier.Final]));\n      fixup.fixup(o.variable(name));\n    }\n    return fixup;\n  }\n\n  getLiteralFactory(literal: o.LiteralArrayExpr|o.LiteralMapExpr):\n      {literalFactory: o.Expression, literalFactoryArguments: o.Expression[]} {\n    // Create a pure function that builds an array of a mix of constant  and variable expressions\n    if (literal instanceof o.LiteralArrayExpr) {\n      const argumentsForKey = literal.entries.map(e => e.isConstant() ? e : o.literal(null));\n      const key = this.keyOf(o.literalArr(argumentsForKey));\n      return this._getLiteralFactory(key, literal.entries, entries => o.literalArr(entries));\n    } else {\n      const expressionForKey = o.literalMap(\n          literal.entries.map(e => ({\n                                key: e.key,\n                                value: e.value.isConstant() ? e.value : o.literal(null),\n                                quoted: e.quoted\n                              })));\n      const key = this.keyOf(expressionForKey);\n      return this._getLiteralFactory(\n          key, literal.entries.map(e => e.value),\n          entries => o.literalMap(entries.map((value, index) => ({\n                                                key: literal.entries[index].key,\n                                                value,\n                                                quoted: literal.entries[index].quoted\n                                              }))));\n    }\n  }\n\n  private _getLiteralFactory(\n      key: string, values: o.Expression[], resultMap: (parameters: o.Expression[]) => o.Expression):\n      {literalFactory: o.Expression, literalFactoryArguments: o.Expression[]} {\n    let literalFactory = this.literalFactories.get(key);\n    const literalFactoryArguments = values.filter((e => !e.isConstant()));\n    if (!literalFactory) {\n      const resultExpressions = values.map(\n          (e, index) => e.isConstant() ? this.getConstLiteral(e, true) : o.variable(`a${index}`));\n      const parameters =\n          resultExpressions.filter(isVariable).map(e => new o.FnParam(e.name !, o.DYNAMIC_TYPE));\n      const pureFunctionDeclaration =\n          o.fn(parameters, [new o.ReturnStatement(resultMap(resultExpressions))], o.INFERRED_TYPE);\n      const name = this.freshName();\n      this.statements.push(\n          o.variable(name).set(pureFunctionDeclaration).toDeclStmt(o.INFERRED_TYPE, [\n            o.StmtModifier.Final\n          ]));\n      literalFactory = o.variable(name);\n      this.literalFactories.set(key, literalFactory);\n    }\n    return {literalFactory, literalFactoryArguments};\n  }\n\n  /**\n   * Produce a unique name.\n   *\n   * The name might be unique among different prefixes if any of the prefixes end in\n   * a digit so the prefix should be a constant string (not based on user input) and\n   * must not end in a digit.\n   */\n  uniqueName(prefix: string): string { return `${prefix}${this.nextNameIndex++}`; }\n\n  private definitionsOf(kind: DefinitionKind): Map<any, FixupExpression> {\n    switch (kind) {\n      case DefinitionKind.Component:\n        return this.componentDefinitions;\n      case DefinitionKind.Directive:\n        return this.directiveDefinitions;\n      case DefinitionKind.Injector:\n        return this.injectorDefinitions;\n      case DefinitionKind.Pipe:\n        return this.pipeDefinitions;\n    }\n    error(`Unknown definition kind ${kind}`);\n    return this.componentDefinitions;\n  }\n\n  public propertyNameOf(kind: DefinitionKind): string {\n    switch (kind) {\n      case DefinitionKind.Component:\n        return 'ngComponentDef';\n      case DefinitionKind.Directive:\n        return 'ngDirectiveDef';\n      case DefinitionKind.Injector:\n        return 'ngInjectorDef';\n      case DefinitionKind.Pipe:\n        return 'ngPipeDef';\n    }\n    error(`Unknown definition kind ${kind}`);\n    return '<unknown>';\n  }\n\n  private freshName(): string { return this.uniqueName(CONSTANT_PREFIX); }\n\n  private keyOf(expression: o.Expression) {\n    return expression.visitExpression(new KeyVisitor(), KEY_CONTEXT);\n  }\n}\n\n/**\n * Visitor used to determine if 2 expressions are equivalent and can be shared in the\n * `ConstantPool`.\n *\n * When the id (string) generated by the visitor is equal, expressions are considered equivalent.\n */\nclass KeyVisitor implements o.ExpressionVisitor {\n  visitLiteralExpr(ast: o.LiteralExpr): string {\n    return `${typeof ast.value === 'string' ? '\"' + ast.value + '\"' : ast.value}`;\n  }\n\n  visitLiteralArrayExpr(ast: o.LiteralArrayExpr, context: object): string {\n    return `[${ast.entries.map(entry => entry.visitExpression(this, context)).join(',')}]`;\n  }\n\n  visitLiteralMapExpr(ast: o.LiteralMapExpr, context: object): string {\n    const mapKey = (entry: o.LiteralMapEntry) => {\n      const quote = entry.quoted ? '\"' : '';\n      return `${quote}${entry.key}${quote}`;\n    };\n    const mapEntry = (entry: o.LiteralMapEntry) =>\n        `${mapKey(entry)}:${entry.value.visitExpression(this, context)}`;\n    return `{${ast.entries.map(mapEntry).join(',')}`;\n  }\n\n  visitExternalExpr(ast: o.ExternalExpr): string {\n    return ast.value.moduleName ? `EX:${ast.value.moduleName}:${ast.value.name}` :\n                                  `EX:${ast.value.runtime.name}`;\n  }\n\n  visitReadVarExpr(node: o.ReadVarExpr) { return `VAR:${node.name}`; }\n\n  visitTypeofExpr(node: o.TypeofExpr, context: any): string {\n    return `TYPEOF:${node.expr.visitExpression(this, context)}`;\n  }\n\n  visitWrappedNodeExpr = invalid;\n  visitWriteVarExpr = invalid;\n  visitWriteKeyExpr = invalid;\n  visitWritePropExpr = invalid;\n  visitInvokeMethodExpr = invalid;\n  visitInvokeFunctionExpr = invalid;\n  visitInstantiateExpr = invalid;\n  visitConditionalExpr = invalid;\n  visitNotExpr = invalid;\n  visitAssertNotNullExpr = invalid;\n  visitCastExpr = invalid;\n  visitFunctionExpr = invalid;\n  visitBinaryOperatorExpr = invalid;\n  visitReadPropExpr = invalid;\n  visitReadKeyExpr = invalid;\n  visitCommaExpr = invalid;\n}\n\nfunction invalid<T>(this: o.ExpressionVisitor, arg: o.Expression | o.Statement): never {\n  throw new Error(\n      `Invalid state: Visitor ${this.constructor.name} doesn't handle ${arg.constructor.name}`);\n}\n\nfunction isVariable(e: o.Expression): e is o.ReadVarExpr {\n  return e instanceof o.ReadVarExpr;\n}\n"]}
\No newline at end of file