@angular/language-service 9.1.3 → 9.1.7
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/bundles/language-service.umd.js +722 -548
- package/package.json +1 -1
- package/src/completions.js +6 -4
- package/src/definitions.js +10 -9
- package/src/diagnostics.js +6 -5
- package/src/expression_type.js +30 -19
- package/src/expressions.js +17 -20
- package/src/ts_utils.d.ts +71 -0
- package/src/ts_utils.js +149 -0
- package/src/typescript_host.js +19 -8
- package/src/utils.d.ts +0 -70
- package/src/utils.js +8 -145
package/src/utils.js
CHANGED
|
@@ -11,14 +11,13 @@
|
|
|
11
11
|
if (v !== undefined) module.exports = v;
|
|
12
12
|
}
|
|
13
13
|
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/language-service/src/utils", ["require", "exports", "tslib", "@angular/compiler"
|
|
14
|
+
define("@angular/language-service/src/utils", ["require", "exports", "tslib", "@angular/compiler"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
19
|
var tslib_1 = require("tslib");
|
|
20
20
|
var compiler_1 = require("@angular/compiler");
|
|
21
|
-
var ts = require("typescript");
|
|
22
21
|
function isParseSourceSpan(value) {
|
|
23
22
|
return value && !!value.start;
|
|
24
23
|
}
|
|
@@ -181,84 +180,6 @@
|
|
|
181
180
|
return new compiler_1.AstPath(path, position);
|
|
182
181
|
}
|
|
183
182
|
exports.findTemplateAstAt = findTemplateAstAt;
|
|
184
|
-
/**
|
|
185
|
-
* Return the node that most tightly encompass the specified `position`.
|
|
186
|
-
* @param node
|
|
187
|
-
* @param position
|
|
188
|
-
*/
|
|
189
|
-
function findTightestNode(node, position) {
|
|
190
|
-
if (node.getStart() <= position && position < node.getEnd()) {
|
|
191
|
-
return node.forEachChild(function (c) { return findTightestNode(c, position); }) || node;
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
exports.findTightestNode = findTightestNode;
|
|
195
|
-
/**
|
|
196
|
-
* Return metadata about `node` if it looks like an Angular directive class.
|
|
197
|
-
* In this case, potential matches are `@NgModule`, `@Component`, `@Directive`,
|
|
198
|
-
* `@Pipe`, etc.
|
|
199
|
-
* These class declarations all share some common attributes, namely their
|
|
200
|
-
* decorator takes exactly one parameter and the parameter must be an object
|
|
201
|
-
* literal.
|
|
202
|
-
*
|
|
203
|
-
* For example,
|
|
204
|
-
* v---------- `decoratorId`
|
|
205
|
-
* @NgModule({ <
|
|
206
|
-
* declarations: [], < classDecl
|
|
207
|
-
* }) <
|
|
208
|
-
* class AppModule {} <
|
|
209
|
-
* ^----- `classId`
|
|
210
|
-
*
|
|
211
|
-
* @param node Potential node that represents an Angular directive.
|
|
212
|
-
*/
|
|
213
|
-
function getDirectiveClassLike(node) {
|
|
214
|
-
var e_4, _a;
|
|
215
|
-
if (!ts.isClassDeclaration(node) || !node.name || !node.decorators) {
|
|
216
|
-
return;
|
|
217
|
-
}
|
|
218
|
-
try {
|
|
219
|
-
for (var _b = tslib_1.__values(node.decorators), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
220
|
-
var d = _c.value;
|
|
221
|
-
var expr = d.expression;
|
|
222
|
-
if (!ts.isCallExpression(expr) || expr.arguments.length !== 1 ||
|
|
223
|
-
!ts.isIdentifier(expr.expression)) {
|
|
224
|
-
continue;
|
|
225
|
-
}
|
|
226
|
-
var arg = expr.arguments[0];
|
|
227
|
-
if (ts.isObjectLiteralExpression(arg)) {
|
|
228
|
-
return {
|
|
229
|
-
decoratorId: expr.expression,
|
|
230
|
-
classId: node.name,
|
|
231
|
-
};
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
|
236
|
-
finally {
|
|
237
|
-
try {
|
|
238
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
239
|
-
}
|
|
240
|
-
finally { if (e_4) throw e_4.error; }
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
exports.getDirectiveClassLike = getDirectiveClassLike;
|
|
244
|
-
/**
|
|
245
|
-
* Finds the value of a property assignment that is nested in a TypeScript node and is of a certain
|
|
246
|
-
* type T.
|
|
247
|
-
*
|
|
248
|
-
* @param startNode node to start searching for nested property assignment from
|
|
249
|
-
* @param propName property assignment name
|
|
250
|
-
* @param predicate function to verify that a node is of type T.
|
|
251
|
-
* @return node property assignment value of type T, or undefined if none is found
|
|
252
|
-
*/
|
|
253
|
-
function findPropertyValueOfType(startNode, propName, predicate) {
|
|
254
|
-
if (ts.isPropertyAssignment(startNode) && startNode.name.getText() === propName) {
|
|
255
|
-
var initializer = startNode.initializer;
|
|
256
|
-
if (predicate(initializer))
|
|
257
|
-
return initializer;
|
|
258
|
-
}
|
|
259
|
-
return startNode.forEachChild(function (c) { return findPropertyValueOfType(c, propName, predicate); });
|
|
260
|
-
}
|
|
261
|
-
exports.findPropertyValueOfType = findPropertyValueOfType;
|
|
262
183
|
/**
|
|
263
184
|
* Find the tightest node at the specified `position` from the AST `nodes`, and
|
|
264
185
|
* return the path to the node.
|
|
@@ -293,7 +214,7 @@
|
|
|
293
214
|
* Inverts an object's key-value pairs.
|
|
294
215
|
*/
|
|
295
216
|
function invertMap(obj) {
|
|
296
|
-
var
|
|
217
|
+
var e_4, _a;
|
|
297
218
|
var result = {};
|
|
298
219
|
try {
|
|
299
220
|
for (var _b = tslib_1.__values(Object.keys(obj)), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
@@ -302,12 +223,12 @@
|
|
|
302
223
|
result[v] = name_1;
|
|
303
224
|
}
|
|
304
225
|
}
|
|
305
|
-
catch (
|
|
226
|
+
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
|
306
227
|
finally {
|
|
307
228
|
try {
|
|
308
229
|
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
309
230
|
}
|
|
310
|
-
finally { if (
|
|
231
|
+
finally { if (e_4) throw e_4.error; }
|
|
311
232
|
}
|
|
312
233
|
return result;
|
|
313
234
|
}
|
|
@@ -318,7 +239,7 @@
|
|
|
318
239
|
* @param path narrowing
|
|
319
240
|
*/
|
|
320
241
|
function findOutputBinding(binding, path, query) {
|
|
321
|
-
var
|
|
242
|
+
var e_5, _a;
|
|
322
243
|
var element = path.first(compiler_1.ElementAst);
|
|
323
244
|
if (element) {
|
|
324
245
|
try {
|
|
@@ -334,73 +255,15 @@
|
|
|
334
255
|
}
|
|
335
256
|
}
|
|
336
257
|
}
|
|
337
|
-
catch (
|
|
258
|
+
catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
|
338
259
|
finally {
|
|
339
260
|
try {
|
|
340
261
|
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
341
262
|
}
|
|
342
|
-
finally { if (
|
|
263
|
+
finally { if (e_5) throw e_5.error; }
|
|
343
264
|
}
|
|
344
265
|
}
|
|
345
266
|
}
|
|
346
267
|
exports.findOutputBinding = findOutputBinding;
|
|
347
|
-
/**
|
|
348
|
-
* Returns a property assignment from the assignment value, or `undefined` if there is no
|
|
349
|
-
* assignment.
|
|
350
|
-
*/
|
|
351
|
-
function getPropertyAssignmentFromValue(value) {
|
|
352
|
-
if (!value.parent || !ts.isPropertyAssignment(value.parent)) {
|
|
353
|
-
return;
|
|
354
|
-
}
|
|
355
|
-
return value.parent;
|
|
356
|
-
}
|
|
357
|
-
exports.getPropertyAssignmentFromValue = getPropertyAssignmentFromValue;
|
|
358
|
-
/**
|
|
359
|
-
* Given a decorator property assignment, return the ClassDeclaration node that corresponds to the
|
|
360
|
-
* directive class the property applies to.
|
|
361
|
-
* If the property assignment is not on a class decorator, no declaration is returned.
|
|
362
|
-
*
|
|
363
|
-
* For example,
|
|
364
|
-
*
|
|
365
|
-
* @Component({
|
|
366
|
-
* template: '<div></div>'
|
|
367
|
-
* ^^^^^^^^^^^^^^^^^^^^^^^---- property assignment
|
|
368
|
-
* })
|
|
369
|
-
* class AppComponent {}
|
|
370
|
-
* ^---- class declaration node
|
|
371
|
-
*
|
|
372
|
-
* @param propAsgn property assignment
|
|
373
|
-
*/
|
|
374
|
-
function getClassDeclFromDecoratorProp(propAsgnNode) {
|
|
375
|
-
if (!propAsgnNode.parent || !ts.isObjectLiteralExpression(propAsgnNode.parent)) {
|
|
376
|
-
return;
|
|
377
|
-
}
|
|
378
|
-
var objLitExprNode = propAsgnNode.parent;
|
|
379
|
-
if (!objLitExprNode.parent || !ts.isCallExpression(objLitExprNode.parent)) {
|
|
380
|
-
return;
|
|
381
|
-
}
|
|
382
|
-
var callExprNode = objLitExprNode.parent;
|
|
383
|
-
if (!callExprNode.parent || !ts.isDecorator(callExprNode.parent)) {
|
|
384
|
-
return;
|
|
385
|
-
}
|
|
386
|
-
var decorator = callExprNode.parent;
|
|
387
|
-
if (!decorator.parent || !ts.isClassDeclaration(decorator.parent)) {
|
|
388
|
-
return;
|
|
389
|
-
}
|
|
390
|
-
var classDeclNode = decorator.parent;
|
|
391
|
-
return classDeclNode;
|
|
392
|
-
}
|
|
393
|
-
exports.getClassDeclFromDecoratorProp = getClassDeclFromDecoratorProp;
|
|
394
|
-
/**
|
|
395
|
-
* Determines if a property assignment is on a class decorator.
|
|
396
|
-
* See `getClassDeclFromDecoratorProperty`, which gets the class the decorator is applied to, for
|
|
397
|
-
* more details.
|
|
398
|
-
*
|
|
399
|
-
* @param prop property assignment
|
|
400
|
-
*/
|
|
401
|
-
function isClassDecoratorProperty(propAsgn) {
|
|
402
|
-
return !!getClassDeclFromDecoratorProp(propAsgn);
|
|
403
|
-
}
|
|
404
|
-
exports.isClassDecoratorProperty = isClassDecoratorProperty;
|
|
405
268
|
});
|
|
406
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH,8CAA6U;IAC7U,+BAAiC;IAUjC,SAAS,iBAAiB,CAAC,KAAU;QACnC,OAAO,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;IAChC,CAAC;IAKD,SAAgB,MAAM,CAAC,IAAiC;QACtD,IAAI,CAAC,IAAI;YAAE,OAAO,SAAS,CAAC;QAC5B,IAAI,iBAAiB,CAAC,IAAI,CAAC,EAAE;YAC3B,OAAO,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,EAAC,CAAC;SACzD;aAAM;YACL,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,OAAO,EAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,EAAC,CAAC;aAClF;iBAAM,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;gBAChD,OAAO;oBACL,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM;oBACnC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAE,CAAC,GAAG;iBAC1D,CAAC;aACH;YACD,OAAO,EAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,EAAC,CAAC;SAC/E;IACH,CAAC;IAfD,wBAeC;IAED,SAAgB,MAAM,CAAC,QAAgB,EAAE,IAAW,EAAE,SAAmB;QACvE,OAAO,IAAI,IAAI,IAAI;YACf,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC/C,QAAQ,IAAI,IAAI,CAAC,KAAK,IAAI,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;IACnE,CAAC;IAJD,wBAIC;IAED,SAAgB,UAAU,CAAC,IAAU,EAAE,MAAc;QACnD,OAAO,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,GAAG,MAAM,EAAC,CAAC;IAC9D,CAAC;IAFD,gCAEC;IAED,SAAgB,UAAU,CAAC,KAAW,EAAE,KAAW;QACjD,OAAO,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC;IAC9D,CAAC;IAFD,gCAEC;IAED,SAAgB,qBAAqB,CAAC,IAAyB;;;;YAC7D,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,MAAM,CAAA,gBAAA,4BAAE;gBAA5B,IAAM,KAAK,WAAA;gBACd,IAAM,SAAS,GAAG,yBAAc,OAAC,KAAK,CAAC,KAAK,0CAAE,UAAU,CAAC,CAAC;gBAC1D,IAAI,SAAS,KAAK,sBAAW,CAAC,WAAW,CAAC,IAAI;oBAC1C,SAAS,KAAK,sBAAW,CAAC,gBAAgB,CAAC,IAAI,EAAE;oBACnD,OAAO,IAAI,CAAC;iBACb;aACF;;;;;;;;;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IATD,sDASC;IAED,SAAgB,YAAY,CAAC,IAAe;;QAC1C,IAAM,GAAG,GAAG,IAAI,GAAG,EAAwC,CAAC;QAC5D,IAAM,OAAO,GAAkB,EAAE,CAAC;;YAClC,KAAwB,IAAA,KAAA,iBAAA,IAAI,CAAC,UAAU,CAAA,gBAAA,4BAAE;gBAApC,IAAM,SAAS,WAAA;gBAClB,IAAM,SAAS,GAAkB,sBAAW,CAAC,KAAK,CAAC,SAAS,CAAC,QAAS,CAAC,CAAC;;oBACxE,KAAuB,IAAA,6BAAA,iBAAA,SAAS,CAAA,CAAA,oCAAA,2DAAE;wBAA7B,IAAM,QAAQ,sBAAA;wBACjB,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBACvB,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;qBAC9B;;;;;;;;;aACF;;;;;;;;;QACD,OAAO,EAAC,SAAS,EAAE,OAAO,EAAE,GAAG,KAAA,EAAC,CAAC;IACnC,CAAC;IAXD,oCAWC;IAED,SAAgB,8BAA8B,CAAC,IAAe;QAC5D,OAAO;YACL,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ;YAChC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK;YAChC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK;YAC1B,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO;YAC9B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM;SAC7B,CAAC;IACJ,CAAC;IAVD,wEAUC;IAED,SAAgB,iBAAiB,CAAC,GAAkB,EAAE,QAAgB;QACpE,IAAM,IAAI,GAAkB,EAAE,CAAC;QAC/B,IAAM,OAAO,GAAG;YAAkB,mCAA2B;YAAzC;;YA8CpB,CAAC;YA7CC,uBAAK,GAAL,UAAM,GAAgB;gBACpB,IAAI,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;gBACvB,IAAI,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE;oBAC1B,IAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC;oBACxB,IAAI,CAAC,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;wBACnD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;qBAChB;iBACF;qBAAM;oBACL,oEAAoE;oBACpE,OAAO,IAAI,CAAC;iBACb;YACH,CAAC;YAED,uCAAqB,GAArB,UAAsB,GAAwB,EAAE,OAAY;gBAC1D,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,UAAA,KAAK;oBACtC,2CAA2C;oBAC3C,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACjB,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACtB,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACtB,CAAC,CAAC,CAAC;YACL,CAAC;YAED,8BAAY,GAAZ,UAAa,GAAe,EAAE,OAAY;gBACxC,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,UAAA,KAAK;oBACtC,oBAAoB;oBACpB,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACjB,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;oBAClB,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACnB,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACtB,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACtB,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACtB,CAAC,CAAC,CAAC;YACL,CAAC;YAED,gCAAc,GAAd,UAAe,GAAiB,EAAE,OAAY;gBAC5C,4CAA4C;gBAC5C,IAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,UAAA,KAAK;oBAC9C,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBACpB,CAAC,CAAC,CAAC;gBACH,4DAA4D;gBAC5D,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,EAAE;oBACjC,IAAI,CAAC,GAAG,EAAE,CAAC;iBACZ;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC;YACH,cAAC;QAAD,CAAC,AA9CmB,CAAc,sCAA2B,EA8C5D,CAAC;QAEF,2BAAgB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAE/B,OAAO,IAAI,kBAAO,CAAc,IAAI,EAAE,QAAQ,CAAC,CAAC;IAClD,CAAC;IArDD,8CAqDC;IAED;;;;OAIG;IACH,SAAgB,gBAAgB,CAAC,IAAa,EAAE,QAAgB;QAC9D,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,QAAQ,IAAI,QAAQ,GAAG,IAAI,CAAC,MAAM,EAAE,EAAE;YAC3D,OAAO,IAAI,CAAC,YAAY,CAAC,UAAA,CAAC,IAAI,OAAA,gBAAgB,CAAC,CAAC,EAAE,QAAQ,CAAC,EAA7B,CAA6B,CAAC,IAAI,IAAI,CAAC;SACtE;IACH,CAAC;IAJD,4CAIC;IAOD;;;;;;;;;;;;;;;;;OAiBG;IACH,SAAgB,qBAAqB,CAAC,IAAa;;QACjD,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClE,OAAO;SACR;;YACD,KAAgB,IAAA,KAAA,iBAAA,IAAI,CAAC,UAAU,CAAA,gBAAA,4BAAE;gBAA5B,IAAM,CAAC,WAAA;gBACV,IAAM,IAAI,GAAG,CAAC,CAAC,UAAU,CAAC;gBAC1B,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;oBACzD,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;oBACrC,SAAS;iBACV;gBACD,IAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAC9B,IAAI,EAAE,CAAC,yBAAyB,CAAC,GAAG,CAAC,EAAE;oBACrC,OAAO;wBACL,WAAW,EAAE,IAAI,CAAC,UAAU;wBAC5B,OAAO,EAAE,IAAI,CAAC,IAAI;qBACnB,CAAC;iBACH;aACF;;;;;;;;;IACH,CAAC;IAlBD,sDAkBC;IAED;;;;;;;;OAQG;IACH,SAAgB,uBAAuB,CACnC,SAAkB,EAAE,QAAgB,EAAE,SAAuC;QAC/E,IAAI,EAAE,CAAC,oBAAoB,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,QAAQ,EAAE;YACxE,IAAA,mCAAW,CAAc;YAChC,IAAI,SAAS,CAAC,WAAW,CAAC;gBAAE,OAAO,WAAW,CAAC;SAChD;QACD,OAAO,SAAS,CAAC,YAAY,CAAC,UAAA,CAAC,IAAI,OAAA,uBAAuB,CAAC,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,EAA/C,CAA+C,CAAC,CAAC;IACtF,CAAC;IAPD,0DAOC;IAED;;;;;OAKG;IACH,SAAgB,uBAAuB,CAAC,KAAa,EAAE,QAAgB;QACrE,IAAM,IAAI,GAAW,EAAE,CAAC;QACxB,IAAM,OAAO,GAAG;YAAkB,mCAAgB;YAA9B;;YAWpB,CAAC;YAVC,uBAAK,GAAL,UAAM,GAAS;gBACb,IAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;gBACzB,IAAI,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE;oBAC1B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAChB;qBAAM;oBACL,qEAAqE;oBACrE,aAAa;oBACb,OAAO,IAAI,CAAC;iBACb;YACH,CAAC;YACH,cAAC;QAAD,CAAC,AAXmB,CAAc,2BAAgB,EAWjD,CAAC;QACF,mBAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACzB,OAAO,IAAI,kBAAO,CAAO,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC3C,CAAC;IAhBD,0DAgBC;IAGD;;OAEG;IACH,SAAgB,SAAS,CAAC,GAA6B;;QACrD,IAAM,MAAM,GAA6B,EAAE,CAAC;;YAC5C,KAAmB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA,gBAAA,4BAAE;gBAAhC,IAAM,MAAI,WAAA;gBACb,IAAM,CAAC,GAAG,GAAG,CAAC,MAAI,CAAC,CAAC;gBACpB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAI,CAAC;aAClB;;;;;;;;;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAPD,8BAOC;IAGD;;;;OAIG;IACH,SAAgB,iBAAiB,CAC7B,OAAsB,EAAE,IAAqB,EAAE,KAAkB;;QACnE,IAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,qBAAU,CAAC,CAAC;QACvC,IAAI,OAAO,EAAE;;gBACX,KAAwB,IAAA,KAAA,iBAAA,OAAO,CAAC,UAAU,CAAA,gBAAA,4BAAE;oBAAvC,IAAM,SAAS,WAAA;oBAClB,IAAM,eAAe,GAAG,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;oBAC/D,IAAM,SAAS,GAAG,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChD,IAAI,SAAS,EAAE;wBACb,IAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC5E,IAAI,WAAW,EAAE;4BACf,OAAO,WAAW,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;yBAC7C;qBACF;iBACF;;;;;;;;;SACF;IACH,CAAC;IAfD,8CAeC;IAED;;;OAGG;IACH,SAAgB,8BAA8B,CAAC,KAAc;QAC3D,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC3D,OAAO;SACR;QACD,OAAO,KAAK,CAAC,MAAM,CAAC;IACtB,CAAC;IALD,wEAKC;IAED;;;;;;;;;;;;;;;OAeG;IACH,SAAgB,6BAA6B,CAAC,YAAmC;QAE/E,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,yBAAyB,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAC9E,OAAO;SACR;QACD,IAAM,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE;YACzE,OAAO;SACR;QACD,IAAM,YAAY,GAAG,cAAc,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAChE,OAAO;SACR;QACD,IAAM,SAAS,GAAG,YAAY,CAAC,MAAM,CAAC;QACtC,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACjE,OAAO;SACR;QACD,IAAM,aAAa,GAAG,SAAS,CAAC,MAAM,CAAC;QACvC,OAAO,aAAa,CAAC;IACvB,CAAC;IAnBD,sEAmBC;IAED;;;;;;OAMG;IACH,SAAgB,wBAAwB,CAAC,QAA+B;QACtE,OAAO,CAAC,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAFD,4DAEC","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 {AstPath, BoundEventAst, CompileDirectiveSummary, CompileTypeMetadata, CssSelector, DirectiveAst, ElementAst, EmbeddedTemplateAst, HtmlAstPath, identifierName, Identifiers, Node, ParseSourceSpan, RecursiveTemplateAstVisitor, RecursiveVisitor, TemplateAst, TemplateAstPath, templateVisitAll, visitAll} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {AstResult, DiagnosticTemplateInfo, SelectorInfo, Span, Symbol, SymbolQuery} from './types';\n\ninterface SpanHolder {\n  sourceSpan: ParseSourceSpan;\n  endSourceSpan?: ParseSourceSpan|null;\n  children?: SpanHolder[];\n}\n\nfunction isParseSourceSpan(value: any): value is ParseSourceSpan {\n  return value && !!value.start;\n}\n\nexport function spanOf(span: SpanHolder): Span;\nexport function spanOf(span: ParseSourceSpan): Span;\nexport function spanOf(span: SpanHolder|ParseSourceSpan|undefined): Span|undefined;\nexport function spanOf(span?: SpanHolder|ParseSourceSpan): Span|undefined {\n  if (!span) return undefined;\n  if (isParseSourceSpan(span)) {\n    return {start: span.start.offset, end: span.end.offset};\n  } else {\n    if (span.endSourceSpan) {\n      return {start: span.sourceSpan.start.offset, end: span.endSourceSpan.end.offset};\n    } else if (span.children && span.children.length) {\n      return {\n        start: span.sourceSpan.start.offset,\n        end: spanOf(span.children[span.children.length - 1])!.end\n      };\n    }\n    return {start: span.sourceSpan.start.offset, end: span.sourceSpan.end.offset};\n  }\n}\n\nexport function inSpan(position: number, span?: Span, exclusive?: boolean): boolean {\n  return span != null &&\n      (exclusive ? position >= span.start && position < span.end :\n                   position >= span.start && position <= span.end);\n}\n\nexport function offsetSpan(span: Span, amount: number): Span {\n  return {start: span.start + amount, end: span.end + amount};\n}\n\nexport function isNarrower(spanA: Span, spanB: Span): boolean {\n  return spanA.start >= spanB.start && spanA.end <= spanB.end;\n}\n\nexport function isStructuralDirective(type: CompileTypeMetadata): boolean {\n  for (const diDep of type.diDeps) {\n    const diDepName = identifierName(diDep.token?.identifier);\n    if (diDepName === Identifiers.TemplateRef.name ||\n        diDepName === Identifiers.ViewContainerRef.name) {\n      return true;\n    }\n  }\n  return false;\n}\n\nexport function getSelectors(info: AstResult): SelectorInfo {\n  const map = new Map<CssSelector, CompileDirectiveSummary>();\n  const results: CssSelector[] = [];\n  for (const directive of info.directives) {\n    const selectors: CssSelector[] = CssSelector.parse(directive.selector!);\n    for (const selector of selectors) {\n      results.push(selector);\n      map.set(selector, directive);\n    }\n  }\n  return {selectors: results, map};\n}\n\nexport function diagnosticInfoFromTemplateInfo(info: AstResult): DiagnosticTemplateInfo {\n  return {\n    fileName: info.template.fileName,\n    offset: info.template.span.start,\n    query: info.template.query,\n    members: info.template.members,\n    htmlAst: info.htmlAst,\n    templateAst: info.templateAst,\n    source: info.template.source,\n  };\n}\n\nexport function findTemplateAstAt(ast: TemplateAst[], position: number): TemplateAstPath {\n  const path: TemplateAst[] = [];\n  const visitor = new class extends RecursiveTemplateAstVisitor {\n    visit(ast: TemplateAst): any {\n      let span = spanOf(ast);\n      if (inSpan(position, span)) {\n        const len = path.length;\n        if (!len || isNarrower(span, spanOf(path[len - 1]))) {\n          path.push(ast);\n        }\n      } else {\n        // Returning a value here will result in the children being skipped.\n        return true;\n      }\n    }\n\n    visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n      return this.visitChildren(context, visit => {\n        // Ignore reference, variable and providers\n        visit(ast.attrs);\n        visit(ast.directives);\n        visit(ast.children);\n      });\n    }\n\n    visitElement(ast: ElementAst, context: any): any {\n      return this.visitChildren(context, visit => {\n        // Ingnore providers\n        visit(ast.attrs);\n        visit(ast.inputs);\n        visit(ast.outputs);\n        visit(ast.references);\n        visit(ast.directives);\n        visit(ast.children);\n      });\n    }\n\n    visitDirective(ast: DirectiveAst, context: any): any {\n      // Ignore the host properties of a directive\n      const result = this.visitChildren(context, visit => {\n        visit(ast.inputs);\n      });\n      // We never care about the diretive itself, just its inputs.\n      if (path[path.length - 1] === ast) {\n        path.pop();\n      }\n      return result;\n    }\n  };\n\n  templateVisitAll(visitor, ast);\n\n  return new AstPath<TemplateAst>(path, position);\n}\n\n/**\n * Return the node that most tightly encompass the specified `position`.\n * @param node\n * @param position\n */\nexport function findTightestNode(node: ts.Node, position: number): ts.Node|undefined {\n  if (node.getStart() <= position && position < node.getEnd()) {\n    return node.forEachChild(c => findTightestNode(c, position)) || node;\n  }\n}\n\ninterface DirectiveClassLike {\n  decoratorId: ts.Identifier;  // decorator identifier, like @Component\n  classId: ts.Identifier;\n}\n\n/**\n * Return metadata about `node` if it looks like an Angular directive class.\n * In this case, potential matches are `@NgModule`, `@Component`, `@Directive`,\n * `@Pipe`, etc.\n * These class declarations all share some common attributes, namely their\n * decorator takes exactly one parameter and the parameter must be an object\n * literal.\n *\n * For example,\n *     v---------- `decoratorId`\n * @NgModule({           <\n *   declarations: [],   < classDecl\n * })                    <\n * class AppModule {}    <\n *          ^----- `classId`\n *\n * @param node Potential node that represents an Angular directive.\n */\nexport function getDirectiveClassLike(node: ts.Node): DirectiveClassLike|undefined {\n  if (!ts.isClassDeclaration(node) || !node.name || !node.decorators) {\n    return;\n  }\n  for (const d of node.decorators) {\n    const expr = d.expression;\n    if (!ts.isCallExpression(expr) || expr.arguments.length !== 1 ||\n        !ts.isIdentifier(expr.expression)) {\n      continue;\n    }\n    const arg = expr.arguments[0];\n    if (ts.isObjectLiteralExpression(arg)) {\n      return {\n        decoratorId: expr.expression,\n        classId: node.name,\n      };\n    }\n  }\n}\n\n/**\n * Finds the value of a property assignment that is nested in a TypeScript node and is of a certain\n * type T.\n *\n * @param startNode node to start searching for nested property assignment from\n * @param propName property assignment name\n * @param predicate function to verify that a node is of type T.\n * @return node property assignment value of type T, or undefined if none is found\n */\nexport function findPropertyValueOfType<T extends ts.Node>(\n    startNode: ts.Node, propName: string, predicate: (node: ts.Node) => node is T): T|undefined {\n  if (ts.isPropertyAssignment(startNode) && startNode.name.getText() === propName) {\n    const {initializer} = startNode;\n    if (predicate(initializer)) return initializer;\n  }\n  return startNode.forEachChild(c => findPropertyValueOfType(c, propName, predicate));\n}\n\n/**\n * Find the tightest node at the specified `position` from the AST `nodes`, and\n * return the path to the node.\n * @param nodes HTML AST nodes\n * @param position\n */\nexport function getPathToNodeAtPosition(nodes: Node[], position: number): HtmlAstPath {\n  const path: Node[] = [];\n  const visitor = new class extends RecursiveVisitor {\n    visit(ast: Node) {\n      const span = spanOf(ast);\n      if (inSpan(position, span)) {\n        path.push(ast);\n      } else {\n        // Returning a truthy value here will skip all children and terminate\n        // the visit.\n        return true;\n      }\n    }\n  };\n  visitAll(visitor, nodes);\n  return new AstPath<Node>(path, position);\n}\n\n\n/**\n * Inverts an object's key-value pairs.\n */\nexport function invertMap(obj: {[name: string]: string}): {[name: string]: string} {\n  const result: {[name: string]: string} = {};\n  for (const name of Object.keys(obj)) {\n    const v = obj[name];\n    result[v] = name;\n  }\n  return result;\n}\n\n\n/**\n * Finds the directive member providing a template output binding, if one exists.\n * @param info aggregate template AST information\n * @param path narrowing\n */\nexport function findOutputBinding(\n    binding: BoundEventAst, path: TemplateAstPath, query: SymbolQuery): Symbol|undefined {\n  const element = path.first(ElementAst);\n  if (element) {\n    for (const directive of element.directives) {\n      const invertedOutputs = invertMap(directive.directive.outputs);\n      const fieldName = invertedOutputs[binding.name];\n      if (fieldName) {\n        const classSymbol = query.getTypeSymbol(directive.directive.type.reference);\n        if (classSymbol) {\n          return classSymbol.members().get(fieldName);\n        }\n      }\n    }\n  }\n}\n\n/**\n * Returns a property assignment from the assignment value, or `undefined` if there is no\n * assignment.\n */\nexport function getPropertyAssignmentFromValue(value: ts.Node): ts.PropertyAssignment|undefined {\n  if (!value.parent || !ts.isPropertyAssignment(value.parent)) {\n    return;\n  }\n  return value.parent;\n}\n\n/**\n * Given a decorator property assignment, return the ClassDeclaration node that corresponds to the\n * directive class the property applies to.\n * If the property assignment is not on a class decorator, no declaration is returned.\n *\n * For example,\n *\n * @Component({\n *   template: '<div></div>'\n *   ^^^^^^^^^^^^^^^^^^^^^^^---- property assignment\n * })\n * class AppComponent {}\n *           ^---- class declaration node\n *\n * @param propAsgn property assignment\n */\nexport function getClassDeclFromDecoratorProp(propAsgnNode: ts.PropertyAssignment):\n    ts.ClassDeclaration|undefined {\n  if (!propAsgnNode.parent || !ts.isObjectLiteralExpression(propAsgnNode.parent)) {\n    return;\n  }\n  const objLitExprNode = propAsgnNode.parent;\n  if (!objLitExprNode.parent || !ts.isCallExpression(objLitExprNode.parent)) {\n    return;\n  }\n  const callExprNode = objLitExprNode.parent;\n  if (!callExprNode.parent || !ts.isDecorator(callExprNode.parent)) {\n    return;\n  }\n  const decorator = callExprNode.parent;\n  if (!decorator.parent || !ts.isClassDeclaration(decorator.parent)) {\n    return;\n  }\n  const classDeclNode = decorator.parent;\n  return classDeclNode;\n}\n\n/**\n * Determines if a property assignment is on a class decorator.\n * See `getClassDeclFromDecoratorProperty`, which gets the class the decorator is applied to, for\n * more details.\n *\n * @param prop property assignment\n */\nexport function isClassDecoratorProperty(propAsgn: ts.PropertyAssignment): boolean {\n  return !!getClassDeclFromDecoratorProp(propAsgn);\n}\n"]}
|
|
269
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/utils.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 {AstPath, BoundEventAst, CompileDirectiveSummary, CompileTypeMetadata, CssSelector, DirectiveAst, ElementAst, EmbeddedTemplateAst, HtmlAstPath, identifierName, Identifiers, Node, ParseSourceSpan, RecursiveTemplateAstVisitor, RecursiveVisitor, TemplateAst, TemplateAstPath, templateVisitAll, visitAll} from '@angular/compiler';\nimport {AstResult, DiagnosticTemplateInfo, SelectorInfo, Span, Symbol, SymbolQuery} from './types';\n\ninterface SpanHolder {\n  sourceSpan: ParseSourceSpan;\n  endSourceSpan?: ParseSourceSpan|null;\n  children?: SpanHolder[];\n}\n\nfunction isParseSourceSpan(value: any): value is ParseSourceSpan {\n  return value && !!value.start;\n}\n\nexport function spanOf(span: SpanHolder): Span;\nexport function spanOf(span: ParseSourceSpan): Span;\nexport function spanOf(span: SpanHolder|ParseSourceSpan|undefined): Span|undefined;\nexport function spanOf(span?: SpanHolder|ParseSourceSpan): Span|undefined {\n  if (!span) return undefined;\n  if (isParseSourceSpan(span)) {\n    return {start: span.start.offset, end: span.end.offset};\n  } else {\n    if (span.endSourceSpan) {\n      return {start: span.sourceSpan.start.offset, end: span.endSourceSpan.end.offset};\n    } else if (span.children && span.children.length) {\n      return {\n        start: span.sourceSpan.start.offset,\n        end: spanOf(span.children[span.children.length - 1])!.end\n      };\n    }\n    return {start: span.sourceSpan.start.offset, end: span.sourceSpan.end.offset};\n  }\n}\n\nexport function inSpan(position: number, span?: Span, exclusive?: boolean): boolean {\n  return span != null &&\n      (exclusive ? position >= span.start && position < span.end :\n                   position >= span.start && position <= span.end);\n}\n\nexport function offsetSpan(span: Span, amount: number): Span {\n  return {start: span.start + amount, end: span.end + amount};\n}\n\nexport function isNarrower(spanA: Span, spanB: Span): boolean {\n  return spanA.start >= spanB.start && spanA.end <= spanB.end;\n}\n\nexport function isStructuralDirective(type: CompileTypeMetadata): boolean {\n  for (const diDep of type.diDeps) {\n    const diDepName = identifierName(diDep.token?.identifier);\n    if (diDepName === Identifiers.TemplateRef.name ||\n        diDepName === Identifiers.ViewContainerRef.name) {\n      return true;\n    }\n  }\n  return false;\n}\n\nexport function getSelectors(info: AstResult): SelectorInfo {\n  const map = new Map<CssSelector, CompileDirectiveSummary>();\n  const results: CssSelector[] = [];\n  for (const directive of info.directives) {\n    const selectors: CssSelector[] = CssSelector.parse(directive.selector!);\n    for (const selector of selectors) {\n      results.push(selector);\n      map.set(selector, directive);\n    }\n  }\n  return {selectors: results, map};\n}\n\nexport function diagnosticInfoFromTemplateInfo(info: AstResult): DiagnosticTemplateInfo {\n  return {\n    fileName: info.template.fileName,\n    offset: info.template.span.start,\n    query: info.template.query,\n    members: info.template.members,\n    htmlAst: info.htmlAst,\n    templateAst: info.templateAst,\n    source: info.template.source,\n  };\n}\n\nexport function findTemplateAstAt(ast: TemplateAst[], position: number): TemplateAstPath {\n  const path: TemplateAst[] = [];\n  const visitor = new class extends RecursiveTemplateAstVisitor {\n    visit(ast: TemplateAst): any {\n      let span = spanOf(ast);\n      if (inSpan(position, span)) {\n        const len = path.length;\n        if (!len || isNarrower(span, spanOf(path[len - 1]))) {\n          path.push(ast);\n        }\n      } else {\n        // Returning a value here will result in the children being skipped.\n        return true;\n      }\n    }\n\n    visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n      return this.visitChildren(context, visit => {\n        // Ignore reference, variable and providers\n        visit(ast.attrs);\n        visit(ast.directives);\n        visit(ast.children);\n      });\n    }\n\n    visitElement(ast: ElementAst, context: any): any {\n      return this.visitChildren(context, visit => {\n        // Ingnore providers\n        visit(ast.attrs);\n        visit(ast.inputs);\n        visit(ast.outputs);\n        visit(ast.references);\n        visit(ast.directives);\n        visit(ast.children);\n      });\n    }\n\n    visitDirective(ast: DirectiveAst, context: any): any {\n      // Ignore the host properties of a directive\n      const result = this.visitChildren(context, visit => {\n        visit(ast.inputs);\n      });\n      // We never care about the diretive itself, just its inputs.\n      if (path[path.length - 1] === ast) {\n        path.pop();\n      }\n      return result;\n    }\n  };\n\n  templateVisitAll(visitor, ast);\n\n  return new AstPath<TemplateAst>(path, position);\n}\n\n/**\n * Find the tightest node at the specified `position` from the AST `nodes`, and\n * return the path to the node.\n * @param nodes HTML AST nodes\n * @param position\n */\nexport function getPathToNodeAtPosition(nodes: Node[], position: number): HtmlAstPath {\n  const path: Node[] = [];\n  const visitor = new class extends RecursiveVisitor {\n    visit(ast: Node) {\n      const span = spanOf(ast);\n      if (inSpan(position, span)) {\n        path.push(ast);\n      } else {\n        // Returning a truthy value here will skip all children and terminate\n        // the visit.\n        return true;\n      }\n    }\n  };\n  visitAll(visitor, nodes);\n  return new AstPath<Node>(path, position);\n}\n\n\n/**\n * Inverts an object's key-value pairs.\n */\nexport function invertMap(obj: {[name: string]: string}): {[name: string]: string} {\n  const result: {[name: string]: string} = {};\n  for (const name of Object.keys(obj)) {\n    const v = obj[name];\n    result[v] = name;\n  }\n  return result;\n}\n\n\n/**\n * Finds the directive member providing a template output binding, if one exists.\n * @param info aggregate template AST information\n * @param path narrowing\n */\nexport function findOutputBinding(\n    binding: BoundEventAst, path: TemplateAstPath, query: SymbolQuery): Symbol|undefined {\n  const element = path.first(ElementAst);\n  if (element) {\n    for (const directive of element.directives) {\n      const invertedOutputs = invertMap(directive.directive.outputs);\n      const fieldName = invertedOutputs[binding.name];\n      if (fieldName) {\n        const classSymbol = query.getTypeSymbol(directive.directive.type.reference);\n        if (classSymbol) {\n          return classSymbol.members().get(fieldName);\n        }\n      }\n    }\n  }\n}\n"]}
|