1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC 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 | */
|
---|
8 | (function (factory) {
|
---|
9 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
10 | var v = factory(require, exports);
|
---|
11 | if (v !== undefined) module.exports = v;
|
---|
12 | }
|
---|
13 | else if (typeof define === "function" && define.amd) {
|
---|
14 | define("@angular/compiler/src/render3/view/util", ["require", "exports", "tslib", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/util", "@angular/compiler/src/render3/r3_ast", "@angular/compiler/src/render3/view/i18n/util"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.getInterpolationArgsLength = exports.chainedInstruction = exports.getAttrsForDirectiveMatching = exports.DefinitionMap = exports.getQueryPredicate = exports.trimTrailingNulls = exports.conditionallyCreateMapObjectLiteral = exports.asLiteral = exports.invalid = exports.unsupported = exports.temporaryAllocator = exports.RESTORED_VIEW_CONTEXT_NAME = exports.NON_BINDABLE_ATTR = exports.IMPLICIT_REFERENCE = exports.REFERENCE_PREFIX = exports.RENDER_FLAGS = exports.CONTEXT_NAME = exports.TEMPORARY_NAME = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var o = require("@angular/compiler/src/output/output_ast");
|
---|
22 | var util_1 = require("@angular/compiler/src/util");
|
---|
23 | var t = require("@angular/compiler/src/render3/r3_ast");
|
---|
24 | var util_2 = require("@angular/compiler/src/render3/view/i18n/util");
|
---|
25 | /**
|
---|
26 | * Checks whether an object key contains potentially unsafe chars, thus the key should be wrapped in
|
---|
27 | * quotes. Note: we do not wrap all keys into quotes, as it may have impact on minification and may
|
---|
28 | * bot work in some cases when object keys are mangled by minifier.
|
---|
29 | *
|
---|
30 | * TODO(FW-1136): this is a temporary solution, we need to come up with a better way of working with
|
---|
31 | * inputs that contain potentially unsafe chars.
|
---|
32 | */
|
---|
33 | var UNSAFE_OBJECT_KEY_NAME_REGEXP = /[-.]/;
|
---|
34 | /** Name of the temporary to use during data binding */
|
---|
35 | exports.TEMPORARY_NAME = '_t';
|
---|
36 | /** Name of the context parameter passed into a template function */
|
---|
37 | exports.CONTEXT_NAME = 'ctx';
|
---|
38 | /** Name of the RenderFlag passed into a template function */
|
---|
39 | exports.RENDER_FLAGS = 'rf';
|
---|
40 | /** The prefix reference variables */
|
---|
41 | exports.REFERENCE_PREFIX = '_r';
|
---|
42 | /** The name of the implicit context reference */
|
---|
43 | exports.IMPLICIT_REFERENCE = '$implicit';
|
---|
44 | /** Non bindable attribute name **/
|
---|
45 | exports.NON_BINDABLE_ATTR = 'ngNonBindable';
|
---|
46 | /** Name for the variable keeping track of the context returned by `ɵɵrestoreView`. */
|
---|
47 | exports.RESTORED_VIEW_CONTEXT_NAME = 'restoredCtx';
|
---|
48 | /**
|
---|
49 | * Creates an allocator for a temporary variable.
|
---|
50 | *
|
---|
51 | * A variable declaration is added to the statements the first time the allocator is invoked.
|
---|
52 | */
|
---|
53 | function temporaryAllocator(statements, name) {
|
---|
54 | var temp = null;
|
---|
55 | return function () {
|
---|
56 | if (!temp) {
|
---|
57 | statements.push(new o.DeclareVarStmt(exports.TEMPORARY_NAME, undefined, o.DYNAMIC_TYPE));
|
---|
58 | temp = o.variable(name);
|
---|
59 | }
|
---|
60 | return temp;
|
---|
61 | };
|
---|
62 | }
|
---|
63 | exports.temporaryAllocator = temporaryAllocator;
|
---|
64 | function unsupported(feature) {
|
---|
65 | if (this) {
|
---|
66 | throw new Error("Builder " + this.constructor.name + " doesn't support " + feature + " yet");
|
---|
67 | }
|
---|
68 | throw new Error("Feature " + feature + " is not supported yet");
|
---|
69 | }
|
---|
70 | exports.unsupported = unsupported;
|
---|
71 | function invalid(arg) {
|
---|
72 | throw new Error("Invalid state: Visitor " + this.constructor.name + " doesn't handle " + arg.constructor.name);
|
---|
73 | }
|
---|
74 | exports.invalid = invalid;
|
---|
75 | function asLiteral(value) {
|
---|
76 | if (Array.isArray(value)) {
|
---|
77 | return o.literalArr(value.map(asLiteral));
|
---|
78 | }
|
---|
79 | return o.literal(value, o.INFERRED_TYPE);
|
---|
80 | }
|
---|
81 | exports.asLiteral = asLiteral;
|
---|
82 | function conditionallyCreateMapObjectLiteral(keys, keepDeclared) {
|
---|
83 | if (Object.getOwnPropertyNames(keys).length > 0) {
|
---|
84 | return mapToExpression(keys, keepDeclared);
|
---|
85 | }
|
---|
86 | return null;
|
---|
87 | }
|
---|
88 | exports.conditionallyCreateMapObjectLiteral = conditionallyCreateMapObjectLiteral;
|
---|
89 | function mapToExpression(map, keepDeclared) {
|
---|
90 | return o.literalMap(Object.getOwnPropertyNames(map).map(function (key) {
|
---|
91 | var _a, _b;
|
---|
92 | // canonical syntax: `dirProp: publicProp`
|
---|
93 | // if there is no `:`, use dirProp = elProp
|
---|
94 | var value = map[key];
|
---|
95 | var declaredName;
|
---|
96 | var publicName;
|
---|
97 | var minifiedName;
|
---|
98 | var needsDeclaredName;
|
---|
99 | if (Array.isArray(value)) {
|
---|
100 | _a = tslib_1.__read(value, 2), publicName = _a[0], declaredName = _a[1];
|
---|
101 | minifiedName = key;
|
---|
102 | needsDeclaredName = publicName !== declaredName;
|
---|
103 | }
|
---|
104 | else {
|
---|
105 | _b = tslib_1.__read(util_1.splitAtColon(key, [key, value]), 2), declaredName = _b[0], publicName = _b[1];
|
---|
106 | minifiedName = declaredName;
|
---|
107 | // Only include the declared name if extracted from the key, i.e. the key contains a colon.
|
---|
108 | // Otherwise the declared name should be omitted even if it is different from the public name,
|
---|
109 | // as it may have already been minified.
|
---|
110 | needsDeclaredName = publicName !== declaredName && key.includes(':');
|
---|
111 | }
|
---|
112 | return {
|
---|
113 | key: minifiedName,
|
---|
114 | // put quotes around keys that contain potentially unsafe characters
|
---|
115 | quoted: UNSAFE_OBJECT_KEY_NAME_REGEXP.test(minifiedName),
|
---|
116 | value: (keepDeclared && needsDeclaredName) ?
|
---|
117 | o.literalArr([asLiteral(publicName), asLiteral(declaredName)]) :
|
---|
118 | asLiteral(publicName)
|
---|
119 | };
|
---|
120 | }));
|
---|
121 | }
|
---|
122 | /**
|
---|
123 | * Remove trailing null nodes as they are implied.
|
---|
124 | */
|
---|
125 | function trimTrailingNulls(parameters) {
|
---|
126 | while (o.isNull(parameters[parameters.length - 1])) {
|
---|
127 | parameters.pop();
|
---|
128 | }
|
---|
129 | return parameters;
|
---|
130 | }
|
---|
131 | exports.trimTrailingNulls = trimTrailingNulls;
|
---|
132 | function getQueryPredicate(query, constantPool) {
|
---|
133 | if (Array.isArray(query.predicate)) {
|
---|
134 | var predicate_1 = [];
|
---|
135 | query.predicate.forEach(function (selector) {
|
---|
136 | // Each item in predicates array may contain strings with comma-separated refs
|
---|
137 | // (for ex. 'ref, ref1, ..., refN'), thus we extract individual refs and store them
|
---|
138 | // as separate array entities
|
---|
139 | var selectors = selector.split(',').map(function (token) { return o.literal(token.trim()); });
|
---|
140 | predicate_1.push.apply(predicate_1, tslib_1.__spreadArray([], tslib_1.__read(selectors)));
|
---|
141 | });
|
---|
142 | return constantPool.getConstLiteral(o.literalArr(predicate_1), true);
|
---|
143 | }
|
---|
144 | else {
|
---|
145 | return query.predicate;
|
---|
146 | }
|
---|
147 | }
|
---|
148 | exports.getQueryPredicate = getQueryPredicate;
|
---|
149 | /**
|
---|
150 | * A representation for an object literal used during codegen of definition objects. The generic
|
---|
151 | * type `T` allows to reference a documented type of the generated structure, such that the
|
---|
152 | * property names that are set can be resolved to their documented declaration.
|
---|
153 | */
|
---|
154 | var DefinitionMap = /** @class */ (function () {
|
---|
155 | function DefinitionMap() {
|
---|
156 | this.values = [];
|
---|
157 | }
|
---|
158 | DefinitionMap.prototype.set = function (key, value) {
|
---|
159 | if (value) {
|
---|
160 | this.values.push({ key: key, value: value, quoted: false });
|
---|
161 | }
|
---|
162 | };
|
---|
163 | DefinitionMap.prototype.toLiteralMap = function () {
|
---|
164 | return o.literalMap(this.values);
|
---|
165 | };
|
---|
166 | return DefinitionMap;
|
---|
167 | }());
|
---|
168 | exports.DefinitionMap = DefinitionMap;
|
---|
169 | /**
|
---|
170 | * Extract a map of properties to values for a given element or template node, which can be used
|
---|
171 | * by the directive matching machinery.
|
---|
172 | *
|
---|
173 | * @param elOrTpl the element or template in question
|
---|
174 | * @return an object set up for directive matching. For attributes on the element/template, this
|
---|
175 | * object maps a property name to its (static) value. For any bindings, this map simply maps the
|
---|
176 | * property name to an empty string.
|
---|
177 | */
|
---|
178 | function getAttrsForDirectiveMatching(elOrTpl) {
|
---|
179 | var attributesMap = {};
|
---|
180 | if (elOrTpl instanceof t.Template && elOrTpl.tagName !== 'ng-template') {
|
---|
181 | elOrTpl.templateAttrs.forEach(function (a) { return attributesMap[a.name] = ''; });
|
---|
182 | }
|
---|
183 | else {
|
---|
184 | elOrTpl.attributes.forEach(function (a) {
|
---|
185 | if (!util_2.isI18nAttribute(a.name)) {
|
---|
186 | attributesMap[a.name] = a.value;
|
---|
187 | }
|
---|
188 | });
|
---|
189 | elOrTpl.inputs.forEach(function (i) {
|
---|
190 | attributesMap[i.name] = '';
|
---|
191 | });
|
---|
192 | elOrTpl.outputs.forEach(function (o) {
|
---|
193 | attributesMap[o.name] = '';
|
---|
194 | });
|
---|
195 | }
|
---|
196 | return attributesMap;
|
---|
197 | }
|
---|
198 | exports.getAttrsForDirectiveMatching = getAttrsForDirectiveMatching;
|
---|
199 | /** Returns a call expression to a chained instruction, e.g. `property(params[0])(params[1])`. */
|
---|
200 | function chainedInstruction(reference, calls, span) {
|
---|
201 | var expression = o.importExpr(reference, null, span);
|
---|
202 | if (calls.length > 0) {
|
---|
203 | for (var i = 0; i < calls.length; i++) {
|
---|
204 | expression = expression.callFn(calls[i], span);
|
---|
205 | }
|
---|
206 | }
|
---|
207 | else {
|
---|
208 | // Add a blank invocation, in case the `calls` array is empty.
|
---|
209 | expression = expression.callFn([], span);
|
---|
210 | }
|
---|
211 | return expression;
|
---|
212 | }
|
---|
213 | exports.chainedInstruction = chainedInstruction;
|
---|
214 | /**
|
---|
215 | * Gets the number of arguments expected to be passed to a generated instruction in the case of
|
---|
216 | * interpolation instructions.
|
---|
217 | * @param interpolation An interpolation ast
|
---|
218 | */
|
---|
219 | function getInterpolationArgsLength(interpolation) {
|
---|
220 | var expressions = interpolation.expressions, strings = interpolation.strings;
|
---|
221 | if (expressions.length === 1 && strings.length === 2 && strings[0] === '' && strings[1] === '') {
|
---|
222 | // If the interpolation has one interpolated value, but the prefix and suffix are both empty
|
---|
223 | // strings, we only pass one argument, to a special instruction like `propertyInterpolate` or
|
---|
224 | // `textInterpolate`.
|
---|
225 | return 1;
|
---|
226 | }
|
---|
227 | else {
|
---|
228 | return expressions.length + strings.length;
|
---|
229 | }
|
---|
230 | }
|
---|
231 | exports.getInterpolationArgsLength = getInterpolationArgsLength;
|
---|
232 | });
|
---|
233 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/view/util.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;;IAIH,2DAA6C;IAE7C,mDAAwC;IACxC,wDAA+B;IAG/B,qEAA4C;IAG5C;;;;;;;OAOG;IACH,IAAM,6BAA6B,GAAG,MAAM,CAAC;IAE7C,uDAAuD;IAC1C,QAAA,cAAc,GAAG,IAAI,CAAC;IAEnC,oEAAoE;IACvD,QAAA,YAAY,GAAG,KAAK,CAAC;IAElC,6DAA6D;IAChD,QAAA,YAAY,GAAG,IAAI,CAAC;IAEjC,qCAAqC;IACxB,QAAA,gBAAgB,GAAG,IAAI,CAAC;IAErC,iDAAiD;IACpC,QAAA,kBAAkB,GAAG,WAAW,CAAC;IAE9C,mCAAmC;IACtB,QAAA,iBAAiB,GAAG,eAAe,CAAC;IAEjD,sFAAsF;IACzE,QAAA,0BAA0B,GAAG,aAAa,CAAC;IAExD;;;;OAIG;IACH,SAAgB,kBAAkB,CAAC,UAAyB,EAAE,IAAY;QACxE,IAAI,IAAI,GAAuB,IAAI,CAAC;QACpC,OAAO;YACL,IAAI,CAAC,IAAI,EAAE;gBACT,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,sBAAc,EAAE,SAAS,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;gBACjF,IAAI,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;aACzB;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;IACJ,CAAC;IATD,gDASC;IAGD,SAAgB,WAAW,CAAsB,OAAe;QAC9D,IAAI,IAAI,EAAE;YACR,MAAM,IAAI,KAAK,CAAC,aAAW,IAAI,CAAC,WAAW,CAAC,IAAI,yBAAoB,OAAO,SAAM,CAAC,CAAC;SACpF;QACD,MAAM,IAAI,KAAK,CAAC,aAAW,OAAO,0BAAuB,CAAC,CAAC;IAC7D,CAAC;IALD,kCAKC;IAED,SAAgB,OAAO,CAAqB,GAAoC;QAC9E,MAAM,IAAI,KAAK,CACX,4BAA0B,IAAI,CAAC,WAAW,CAAC,IAAI,wBAAmB,GAAG,CAAC,WAAW,CAAC,IAAM,CAAC,CAAC;IAChG,CAAC;IAHD,0BAGC;IAED,SAAgB,SAAS,CAAC,KAAU;QAClC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;SAC3C;QACD,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IALD,8BAKC;IAED,SAAgB,mCAAmC,CAC/C,IAAsC,EAAE,YAAsB;QAChE,IAAI,MAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/C,OAAO,eAAe,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;SAC5C;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAND,kFAMC;IAED,SAAS,eAAe,CACpB,GAAqC,EAAE,YAAsB;QAC/D,OAAO,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,UAAA,GAAG;;YACzD,0CAA0C;YAC1C,2CAA2C;YAC3C,IAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,IAAI,YAAoB,CAAC;YACzB,IAAI,UAAkB,CAAC;YACvB,IAAI,YAAoB,CAAC;YACzB,IAAI,iBAA0B,CAAC;YAC/B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACxB,KAAA,eAA6B,KAAK,IAAA,EAAjC,UAAU,QAAA,EAAE,YAAY,QAAA,CAAU;gBACnC,YAAY,GAAG,GAAG,CAAC;gBACnB,iBAAiB,GAAG,UAAU,KAAK,YAAY,CAAC;aACjD;iBAAM;gBACL,KAAA,eAA6B,mBAAY,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,IAAA,EAA3D,YAAY,QAAA,EAAE,UAAU,QAAA,CAAoC;gBAC7D,YAAY,GAAG,YAAY,CAAC;gBAC5B,2FAA2F;gBAC3F,8FAA8F;gBAC9F,wCAAwC;gBACxC,iBAAiB,GAAG,UAAU,KAAK,YAAY,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;aACtE;YACD,OAAO;gBACL,GAAG,EAAE,YAAY;gBACjB,oEAAoE;gBACpE,MAAM,EAAE,6BAA6B,CAAC,IAAI,CAAC,YAAY,CAAC;gBACxD,KAAK,EAAE,CAAC,YAAY,IAAI,iBAAiB,CAAC,CAAC,CAAC;oBACxC,CAAC,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;oBAChE,SAAS,CAAC,UAAU,CAAC;aAC1B,CAAC;QACJ,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED;;OAEG;IACH,SAAgB,iBAAiB,CAAC,UAA0B;QAC1D,OAAO,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE;YAClD,UAAU,CAAC,GAAG,EAAE,CAAC;SAClB;QACD,OAAO,UAAU,CAAC;IACpB,CAAC;IALD,8CAKC;IAED,SAAgB,iBAAiB,CAC7B,KAAsB,EAAE,YAA0B;QACpD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;YAClC,IAAI,WAAS,GAAmB,EAAE,CAAC;YACnC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,UAAC,QAAgB;gBACvC,8EAA8E;gBAC9E,mFAAmF;gBACnF,6BAA6B;gBAC7B,IAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,UAAA,KAAK,IAAI,OAAA,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,EAAvB,CAAuB,CAAC,CAAC;gBAC5E,WAAS,CAAC,IAAI,OAAd,WAAS,2CAAS,SAAS,IAAE;YAC/B,CAAC,CAAC,CAAC;YACH,OAAO,YAAY,CAAC,eAAe,CAAC,CAAC,CAAC,UAAU,CAAC,WAAS,CAAC,EAAE,IAAI,CAAC,CAAC;SACpE;aAAM;YACL,OAAO,KAAK,CAAC,SAAS,CAAC;SACxB;IACH,CAAC;IAfD,8CAeC;IAED;;;;OAIG;IACH;QAAA;YACE,WAAM,GAA0D,EAAE,CAAC;QAWrE,CAAC;QATC,2BAAG,GAAH,UAAI,GAAY,EAAE,KAAwB;YACxC,IAAI,KAAK,EAAE;gBACT,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAC,GAAG,EAAE,GAAa,EAAE,KAAK,OAAA,EAAE,MAAM,EAAE,KAAK,EAAC,CAAC,CAAC;aAC9D;QACH,CAAC;QAED,oCAAY,GAAZ;YACE,OAAO,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC;QACH,oBAAC;IAAD,CAAC,AAZD,IAYC;IAZY,sCAAa;IAc1B;;;;;;;;OAQG;IACH,SAAgB,4BAA4B,CAAC,OACU;QACrD,IAAM,aAAa,GAA6B,EAAE,CAAC;QAGnD,IAAI,OAAO,YAAY,CAAC,CAAC,QAAQ,IAAI,OAAO,CAAC,OAAO,KAAK,aAAa,EAAE;YACtE,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,EAA1B,CAA0B,CAAC,CAAC;SAChE;aAAM;YACL,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,UAAA,CAAC;gBAC1B,IAAI,CAAC,sBAAe,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;oBAC5B,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;iBACjC;YACH,CAAC,CAAC,CAAC;YAEH,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,UAAA,CAAC;gBACtB,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YAC7B,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,UAAA,CAAC;gBACvB,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YAC7B,CAAC,CAAC,CAAC;SACJ;QAED,OAAO,aAAa,CAAC;IACvB,CAAC;IAvBD,oEAuBC;IAED,iGAAiG;IACjG,SAAgB,kBAAkB,CAC9B,SAA8B,EAAE,KAAuB,EAAE,IAA2B;QACtF,IAAI,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAiB,CAAC;QAErE,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACrC,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;aAChD;SACF;aAAM;YACL,8DAA8D;YAC9D,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;SAC1C;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;IAdD,gDAcC;IAED;;;;OAIG;IACH,SAAgB,0BAA0B,CAAC,aAA4B;QAC9D,IAAA,WAAW,GAAa,aAAa,YAA1B,EAAE,OAAO,GAAI,aAAa,QAAjB,CAAkB;QAC7C,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE;YAC9F,4FAA4F;YAC5F,6FAA6F;YAC7F,qBAAqB;YACrB,OAAO,CAAC,CAAC;SACV;aAAM;YACL,OAAO,WAAW,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;SAC5C;IACH,CAAC;IAVD,gEAUC","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 {ConstantPool} from '../../constant_pool';\nimport {Interpolation} from '../../expression_parser/ast';\nimport * as o from '../../output/output_ast';\nimport {ParseSourceSpan} from '../../parse_util';\nimport {splitAtColon} from '../../util';\nimport * as t from '../r3_ast';\n\nimport {R3QueryMetadata} from './api';\nimport {isI18nAttribute} from './i18n/util';\n\n\n/**\n * Checks whether an object key contains potentially unsafe chars, thus the key should be wrapped in\n * quotes. Note: we do not wrap all keys into quotes, as it may have impact on minification and may\n * bot work in some cases when object keys are mangled by minifier.\n *\n * TODO(FW-1136): this is a temporary solution, we need to come up with a better way of working with\n * inputs that contain potentially unsafe chars.\n */\nconst UNSAFE_OBJECT_KEY_NAME_REGEXP = /[-.]/;\n\n/** Name of the temporary to use during data binding */\nexport const TEMPORARY_NAME = '_t';\n\n/** Name of the context parameter passed into a template function */\nexport const CONTEXT_NAME = 'ctx';\n\n/** Name of the RenderFlag passed into a template function */\nexport const RENDER_FLAGS = 'rf';\n\n/** The prefix reference variables */\nexport const REFERENCE_PREFIX = '_r';\n\n/** The name of the implicit context reference */\nexport const IMPLICIT_REFERENCE = '$implicit';\n\n/** Non bindable attribute name **/\nexport const NON_BINDABLE_ATTR = 'ngNonBindable';\n\n/** Name for the variable keeping track of the context returned by `ɵɵrestoreView`. */\nexport const RESTORED_VIEW_CONTEXT_NAME = 'restoredCtx';\n\n/**\n * Creates an allocator for a temporary variable.\n *\n * A variable declaration is added to the statements the first time the allocator is invoked.\n */\nexport function temporaryAllocator(statements: o.Statement[], name: string): () => o.ReadVarExpr {\n  let temp: o.ReadVarExpr|null = null;\n  return () => {\n    if (!temp) {\n      statements.push(new o.DeclareVarStmt(TEMPORARY_NAME, undefined, o.DYNAMIC_TYPE));\n      temp = o.variable(name);\n    }\n    return temp;\n  };\n}\n\n\nexport function unsupported(this: void|Function, feature: string): never {\n  if (this) {\n    throw new Error(`Builder ${this.constructor.name} doesn't support ${feature} yet`);\n  }\n  throw new Error(`Feature ${feature} is not supported yet`);\n}\n\nexport function invalid<T>(this: t.Visitor, arg: o.Expression|o.Statement|t.Node): never {\n  throw new Error(\n      `Invalid state: Visitor ${this.constructor.name} doesn't handle ${arg.constructor.name}`);\n}\n\nexport function asLiteral(value: any): o.Expression {\n  if (Array.isArray(value)) {\n    return o.literalArr(value.map(asLiteral));\n  }\n  return o.literal(value, o.INFERRED_TYPE);\n}\n\nexport function conditionallyCreateMapObjectLiteral(\n    keys: {[key: string]: string|string[]}, keepDeclared?: boolean): o.Expression|null {\n  if (Object.getOwnPropertyNames(keys).length > 0) {\n    return mapToExpression(keys, keepDeclared);\n  }\n  return null;\n}\n\nfunction mapToExpression(\n    map: {[key: string]: string|string[]}, keepDeclared?: boolean): o.Expression {\n  return o.literalMap(Object.getOwnPropertyNames(map).map(key => {\n    // canonical syntax: `dirProp: publicProp`\n    // if there is no `:`, use dirProp = elProp\n    const value = map[key];\n    let declaredName: string;\n    let publicName: string;\n    let minifiedName: string;\n    let needsDeclaredName: boolean;\n    if (Array.isArray(value)) {\n      [publicName, declaredName] = value;\n      minifiedName = key;\n      needsDeclaredName = publicName !== declaredName;\n    } else {\n      [declaredName, publicName] = splitAtColon(key, [key, value]);\n      minifiedName = declaredName;\n      // Only include the declared name if extracted from the key, i.e. the key contains a colon.\n      // Otherwise the declared name should be omitted even if it is different from the public name,\n      // as it may have already been minified.\n      needsDeclaredName = publicName !== declaredName && key.includes(':');\n    }\n    return {\n      key: minifiedName,\n      // put quotes around keys that contain potentially unsafe characters\n      quoted: UNSAFE_OBJECT_KEY_NAME_REGEXP.test(minifiedName),\n      value: (keepDeclared && needsDeclaredName) ?\n          o.literalArr([asLiteral(publicName), asLiteral(declaredName)]) :\n          asLiteral(publicName)\n    };\n  }));\n}\n\n/**\n *  Remove trailing null nodes as they are implied.\n */\nexport function trimTrailingNulls(parameters: o.Expression[]): o.Expression[] {\n  while (o.isNull(parameters[parameters.length - 1])) {\n    parameters.pop();\n  }\n  return parameters;\n}\n\nexport function getQueryPredicate(\n    query: R3QueryMetadata, constantPool: ConstantPool): o.Expression {\n  if (Array.isArray(query.predicate)) {\n    let predicate: o.Expression[] = [];\n    query.predicate.forEach((selector: string): void => {\n      // Each item in predicates array may contain strings with comma-separated refs\n      // (for ex. 'ref, ref1, ..., refN'), thus we extract individual refs and store them\n      // as separate array entities\n      const selectors = selector.split(',').map(token => o.literal(token.trim()));\n      predicate.push(...selectors);\n    });\n    return constantPool.getConstLiteral(o.literalArr(predicate), true);\n  } else {\n    return query.predicate;\n  }\n}\n\n/**\n * A representation for an object literal used during codegen of definition objects. The generic\n * type `T` allows to reference a documented type of the generated structure, such that the\n * property names that are set can be resolved to their documented declaration.\n */\nexport class DefinitionMap<T = any> {\n  values: {key: string, quoted: boolean, value: o.Expression}[] = [];\n\n  set(key: keyof T, value: o.Expression|null): void {\n    if (value) {\n      this.values.push({key: key as string, value, quoted: false});\n    }\n  }\n\n  toLiteralMap(): o.LiteralMapExpr {\n    return o.literalMap(this.values);\n  }\n}\n\n/**\n * Extract a map of properties to values for a given element or template node, which can be used\n * by the directive matching machinery.\n *\n * @param elOrTpl the element or template in question\n * @return an object set up for directive matching. For attributes on the element/template, this\n * object maps a property name to its (static) value. For any bindings, this map simply maps the\n * property name to an empty string.\n */\nexport function getAttrsForDirectiveMatching(elOrTpl: t.Element|\n                                             t.Template): {[name: string]: string} {\n  const attributesMap: {[name: string]: string} = {};\n\n\n  if (elOrTpl instanceof t.Template && elOrTpl.tagName !== 'ng-template') {\n    elOrTpl.templateAttrs.forEach(a => attributesMap[a.name] = '');\n  } else {\n    elOrTpl.attributes.forEach(a => {\n      if (!isI18nAttribute(a.name)) {\n        attributesMap[a.name] = a.value;\n      }\n    });\n\n    elOrTpl.inputs.forEach(i => {\n      attributesMap[i.name] = '';\n    });\n    elOrTpl.outputs.forEach(o => {\n      attributesMap[o.name] = '';\n    });\n  }\n\n  return attributesMap;\n}\n\n/** Returns a call expression to a chained instruction, e.g. `property(params[0])(params[1])`. */\nexport function chainedInstruction(\n    reference: o.ExternalReference, calls: o.Expression[][], span?: ParseSourceSpan|null) {\n  let expression = o.importExpr(reference, null, span) as o.Expression;\n\n  if (calls.length > 0) {\n    for (let i = 0; i < calls.length; i++) {\n      expression = expression.callFn(calls[i], span);\n    }\n  } else {\n    // Add a blank invocation, in case the `calls` array is empty.\n    expression = expression.callFn([], span);\n  }\n\n  return expression;\n}\n\n/**\n * Gets the number of arguments expected to be passed to a generated instruction in the case of\n * interpolation instructions.\n * @param interpolation An interpolation ast\n */\nexport function getInterpolationArgsLength(interpolation: Interpolation) {\n  const {expressions, strings} = interpolation;\n  if (expressions.length === 1 && strings.length === 2 && strings[0] === '' && strings[1] === '') {\n    // If the interpolation has one interpolated value, but the prefix and suffix are both empty\n    // strings, we only pass one argument, to a special instruction like `propertyInterpolate` or\n    // `textInterpolate`.\n    return 1;\n  } else {\n    return expressions.length + strings.length;\n  }\n}\n"]} |
---|