@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.
@@ -11,7 +11,7 @@
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/expression_type", ["require", "exports", "tslib", "@angular/compiler", "@angular/language-service/src/diagnostic_messages", "@angular/language-service/src/symbols"], factory);
14
+ define("@angular/language-service/src/expression_type", ["require", "exports", "tslib", "@angular/compiler", "@angular/language-service/src/diagnostic_messages", "@angular/language-service/src/symbols", "@angular/language-service/src/utils"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
@@ -20,6 +20,7 @@
20
20
  var compiler_1 = require("@angular/compiler");
21
21
  var diagnostic_messages_1 = require("@angular/language-service/src/diagnostic_messages");
22
22
  var symbols_1 = require("@angular/language-service/src/symbols");
23
+ var utils_1 = require("@angular/language-service/src/utils");
23
24
  // AstType calculatetype of the ast given AST element.
24
25
  var AstType = /** @class */ (function () {
25
26
  function AstType(scope, query, context, source) {
@@ -35,7 +36,7 @@
35
36
  AstType.prototype.getDiagnostics = function (ast) {
36
37
  var type = ast.visit(this);
37
38
  if (this.context.inEvent && type.callable) {
38
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.callable_expression_expected_method_call));
39
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.callable_expression_expected_method_call));
39
40
  }
40
41
  return this.diagnostics;
41
42
  };
@@ -54,7 +55,7 @@
54
55
  // Nullable allowed.
55
56
  break;
56
57
  default:
57
- _this_1.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.expression_might_be_null));
58
+ _this_1.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.expression_might_be_null));
58
59
  break;
59
60
  }
60
61
  }
@@ -127,7 +128,7 @@
127
128
  this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.right.span, diagnostic_messages_1.Diagnostic.expected_a_number_type));
128
129
  return this.anyType;
129
130
  default:
130
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.expected_a_string_or_number_type));
131
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.expected_a_string_or_number_type));
131
132
  return this.anyType;
132
133
  }
133
134
  case '>':
@@ -143,7 +144,7 @@
143
144
  // Two values are comparable only if
144
145
  // - they have some type overlap, or
145
146
  // - at least one is not defined
146
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.expected_operands_of_comparable_types_or_any));
147
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.expected_operands_of_comparable_types_or_any));
147
148
  }
148
149
  return this.query.getBuiltinType(symbols_1.BuiltinType.Boolean);
149
150
  case '&&':
@@ -151,7 +152,7 @@
151
152
  case '||':
152
153
  return this.query.getTypeUnion(leftType, rightType);
153
154
  }
154
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.unrecognized_operator, ast.operation));
155
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.unrecognized_operator, ast.operation));
155
156
  return this.anyType;
156
157
  };
157
158
  AstType.prototype.visitChain = function (ast) {
@@ -189,7 +190,7 @@
189
190
  var args = ast.args.map(function (arg) { return _this_1.getType(arg); });
190
191
  var target = this.getType(ast.target);
191
192
  if (!target || !target.callable) {
192
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.call_target_not_callable, this.sourceOf(ast.target), target.name));
193
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.call_target_not_callable, this.sourceOf(ast.target), target.name));
193
194
  return this.anyType;
194
195
  }
195
196
  var signature = target.selectSignature(args);
@@ -198,7 +199,7 @@
198
199
  }
199
200
  // TODO: Consider a better error message here. See `typescript_symbols#selectSignature` for more
200
201
  // details.
201
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.unable_to_resolve_compatible_call_signature));
202
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.unable_to_resolve_compatible_call_signature));
202
203
  return this.anyType;
203
204
  };
204
205
  AstType.prototype.visitImplicitReceiver = function (_ast) {
@@ -304,7 +305,7 @@
304
305
  case 'number':
305
306
  return this.query.getBuiltinType(symbols_1.BuiltinType.Number);
306
307
  default:
307
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.unrecognized_primitive, typeof ast.value));
308
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.unrecognized_primitive, typeof ast.value));
308
309
  return this.anyType;
309
310
  }
310
311
  }
@@ -318,13 +319,13 @@
318
319
  // by getPipes() is expected to contain symbols with the corresponding transform method type.
319
320
  var pipe = this.query.getPipes().get(ast.name);
320
321
  if (!pipe) {
321
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.no_pipe_found, ast.name));
322
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.no_pipe_found, ast.name));
322
323
  return this.anyType;
323
324
  }
324
325
  var expType = this.getType(ast.exp);
325
326
  var signature = pipe.selectSignature([expType].concat(ast.args.map(function (arg) { return _this_1.getType(arg); })));
326
327
  if (!signature) {
327
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.unable_to_resolve_signature, ast.name));
328
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.unable_to_resolve_signature, ast.name));
328
329
  return this.anyType;
329
330
  }
330
331
  return signature.result;
@@ -393,19 +394,19 @@
393
394
  }
394
395
  var methodType = this.resolvePropertyRead(receiverType, ast);
395
396
  if (!methodType) {
396
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.could_not_resolve_type, ast.name));
397
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.could_not_resolve_type, ast.name));
397
398
  return this.anyType;
398
399
  }
399
400
  if (this.isAny(methodType)) {
400
401
  return this.anyType;
401
402
  }
402
403
  if (!methodType.callable) {
403
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.identifier_not_callable, ast.name));
404
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.identifier_not_callable, ast.name));
404
405
  return this.anyType;
405
406
  }
406
407
  var signature = methodType.selectSignature(ast.args.map(function (arg) { return _this_1.getType(arg); }));
407
408
  if (!signature) {
408
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.unable_to_resolve_signature, ast.name));
409
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.unable_to_resolve_signature, ast.name));
409
410
  return this.anyType;
410
411
  }
411
412
  return signature.result;
@@ -418,20 +419,20 @@
418
419
  var member = receiverType.members().get(ast.name);
419
420
  if (!member) {
420
421
  if (receiverType.name === '$implicit') {
421
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.identifier_not_defined_in_app_context, ast.name));
422
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.identifier_not_defined_in_app_context, ast.name));
422
423
  }
423
424
  else if (receiverType.nullable && ast.receiver instanceof compiler_1.PropertyRead) {
424
425
  var receiver = ast.receiver.name;
425
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.identifier_possibly_undefined, receiver, receiver + "?." + ast.name, receiver + "!." + ast.name));
426
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.identifier_possibly_undefined, receiver, receiver + "?." + ast.name, receiver + "!." + ast.name));
426
427
  }
427
428
  else {
428
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.identifier_not_defined_on_receiver, ast.name, receiverType.name));
429
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.identifier_not_defined_on_receiver, ast.name, receiverType.name));
429
430
  }
430
431
  return this.anyType;
431
432
  }
432
433
  if (!member.public) {
433
434
  var container = receiverType.name === '$implicit' ? 'the component' : "'" + receiverType.name + "'";
434
- this.diagnostics.push(diagnostic_messages_1.createDiagnostic(ast.span, diagnostic_messages_1.Diagnostic.identifier_is_private, ast.name, container));
435
+ this.diagnostics.push(diagnostic_messages_1.createDiagnostic(refinedSpan(ast), diagnostic_messages_1.Diagnostic.identifier_is_private, ast.name, container));
435
436
  }
436
437
  return member.type;
437
438
  };
@@ -442,5 +443,15 @@
442
443
  return AstType;
443
444
  }());
444
445
  exports.AstType = AstType;
446
+ function refinedSpan(ast) {
447
+ // nameSpan is an absolute span, but the spans returned by the expression visitor are expected to
448
+ // be relative to the start of the expression.
449
+ // TODO: migrate to only using absolute spans
450
+ var absoluteOffset = ast.sourceSpan.start - ast.span.start;
451
+ if (ast instanceof compiler_1.ASTWithName) {
452
+ return utils_1.offsetSpan(ast.nameSpan, -absoluteOffset);
453
+ }
454
+ return utils_1.offsetSpan(ast.sourceSpan, -absoluteOffset);
455
+ }
445
456
  });
446
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expression_type.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expression_type.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH,8CAAyT;IAEzT,yFAAmE;IACnE,iEAAmF;IAOnF,sDAAsD;IACtD;QAGE,iBACY,KAAkB,EAAU,KAAkB,EAC9C,OAAqC,EAAU,MAAc;YAD7D,UAAK,GAAL,KAAK,CAAa;YAAU,UAAK,GAAL,KAAK,CAAa;YAC9C,YAAO,GAAP,OAAO,CAA8B;YAAU,WAAM,GAAN,MAAM,CAAQ;YAJxD,gBAAW,GAAoB,EAAE,CAAC;QAIyB,CAAC;QAE7E,yBAAO,GAAP,UAAQ,GAAQ;YACd,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;QAED,gCAAc,GAAd,UAAe,GAAQ;YACrB,IAAM,IAAI,GAAW,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACrC,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,wCAAwC,CAAC,CAAC,CAAC;aACtF;YACD,OAAO,IAAI,CAAC,WAAW,CAAC;QAC1B,CAAC;QAED,6BAAW,GAAX,UAAY,GAAW;YAAvB,mBA0HC;YAzHC,IAAM,OAAO,GAAG,UAAC,GAAQ,EAAE,SAAiB;gBAC1C,IAAM,IAAI,GAAG,OAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACjB,QAAQ,SAAS,EAAE;wBACjB,KAAK,IAAI,CAAC;wBACV,KAAK,IAAI,CAAC;wBACV,KAAK,IAAI,CAAC;wBACV,KAAK,IAAI,CAAC;wBACV,KAAK,KAAK,CAAC;wBACX,KAAK,KAAK;4BACR,oBAAoB;4BACpB,MAAM;wBACR;4BACE,OAAI,CAAC,WAAW,CAAC,IAAI,CAAC,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,wBAAwB,CAAC,CAAC,CAAC;4BACvF,MAAM;qBACT;iBACF;gBACD,OAAO,IAAI,CAAC;YACd,CAAC,CAAC;YAEF,IAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;YAClD,IAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;YACpD,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAClD,IAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAEpD,iEAAiE;YACjE,0DAA0D;YAC1D,wEAAwE;YACxE,IAAM,QAAQ,GAAG,QAAQ,IAAI,CAAC,GAAG,SAAS,CAAC;YAC3C,QAAQ,GAAG,CAAC,SAAS,EAAE;gBACrB,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG,CAAC;gBACT,KAAK,IAAI,CAAC;gBACV,KAAK,IAAI,CAAC;gBACV,KAAK,KAAK,CAAC;gBACX,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG;oBACN,QAAQ,QAAQ,EAAE;wBAChB,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAC5C,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAC/C,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAC/C,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM;4BAC/C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,MAAM,CAAC,CAAC;wBACvD;4BACE,IAAI,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC;4BACxB,QAAQ,QAAQ,EAAE;gCAChB,KAAK,qBAAW,CAAC,GAAG,CAAC;gCACrB,KAAK,qBAAW,CAAC,MAAM;oCACrB,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC;oCACrB,MAAM;6BACT;4BACD,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,QAAQ,CAAC,IAAI,EAAE,gCAAU,CAAC,sBAAsB,CAAC,CAAC,CAAC;4BACxE,OAAO,IAAI,CAAC,OAAO,CAAC;qBACvB;gBACH,KAAK,GAAG;oBACN,QAAQ,QAAQ,EAAE;wBAChB,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAC5C,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,OAAO,CAAC;wBAChD,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAC/C,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,KAAK,CAAC;wBAC9C,KAAK,qBAAW,CAAC,OAAO,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAChD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAC/C,KAAK,qBAAW,CAAC,KAAK,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG;4BAC3C,OAAO,IAAI,CAAC,OAAO,CAAC;wBACtB,KAAK,qBAAW,CAAC,GAAG,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAC/C,KAAK,qBAAW,CAAC,OAAO,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBACnD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAClD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,GAAG,CAAC;wBAC/C,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,OAAO,CAAC;wBACnD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAClD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBAClD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,KAAK,CAAC;wBACjD,KAAK,qBAAW,CAAC,KAAK,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM;4BAC9C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,MAAM,CAAC,CAAC;wBACvD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM;4BAC/C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,MAAM,CAAC,CAAC;wBACvD,KAAK,qBAAW,CAAC,OAAO,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM,CAAC;wBACnD,KAAK,qBAAW,CAAC,KAAK,IAAI,CAAC,GAAG,qBAAW,CAAC,MAAM;4BAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,gCAAU,CAAC,sBAAsB,CAAC,CAAC,CAAC;4BACxE,OAAO,IAAI,CAAC,OAAO,CAAC;wBACtB,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,OAAO,CAAC;wBACnD,KAAK,qBAAW,CAAC,MAAM,IAAI,CAAC,GAAG,qBAAW,CAAC,KAAK;4BAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,gCAAU,CAAC,sBAAsB,CAAC,CAAC,CAAC;4BACzE,OAAO,IAAI,CAAC,OAAO,CAAC;wBACtB;4BACE,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,gCAAgC,CAAC,CAAC,CAAC;4BAC7E,OAAO,IAAI,CAAC,OAAO,CAAC;qBACvB;gBACH,KAAK,GAAG,CAAC;gBACT,KAAK,GAAG,CAAC;gBACT,KAAK,IAAI,CAAC;gBACV,KAAK,IAAI,CAAC;gBACV,KAAK,IAAI,CAAC;gBACV,KAAK,IAAI,CAAC;gBACV,KAAK,KAAK,CAAC;gBACX,KAAK,KAAK;oBACR,IAAI,CAAC,CAAC,QAAQ,GAAG,SAAS,CAAC;wBACvB,CAAC,CAAC,CAAC,QAAQ,GAAG,SAAS,CAAC,GAAG,CAAC,qBAAW,CAAC,IAAI,GAAG,qBAAW,CAAC,SAAS,CAAC,CAAC,EAAE;wBAC1E,oCAAoC;wBACpC,sCAAsC;wBACtC,kCAAkC;wBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,4CAA4C,CAAC,CAAC,CAAC;qBAC1F;oBACD,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,OAAO,CAAC,CAAC;gBACxD,KAAK,IAAI;oBACP,OAAO,SAAS,CAAC;gBACnB,KAAK,IAAI;oBACP,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;aACvD;YAED,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,qBAAqB,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;YACjF,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;QAED,4BAAU,GAAV,UAAW,GAAU;;;gBACnB,sDAAsD;gBACtD,KAAmB,IAAA,KAAA,iBAAA,GAAG,CAAC,WAAW,CAAA,gBAAA,4BAAE;oBAA/B,IAAM,IAAI,WAAA;oBACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;iBAClB;;;;;;;;;YACD,2CAA2C;YAC3C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,SAAS,CAAC,CAAC;QAC1D,CAAC;QAED,kCAAgB,GAAhB,UAAiB,GAAgB;YAC/B,2EAA2E;YAC3E,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1B,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACxB,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACzB,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;QACxF,CAAC;QAED,mCAAiB,GAAjB,UAAkB,GAAiB;YAAnC,mBAqBC;YApBC,4EAA4E;YAC5E,iFAAiF;YACjF,8EAA8E;YAC9E,WAAW;YACX,IAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,OAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAjB,CAAiB,CAAC,CAAC;YACpD,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAO,CAAC,CAAC;YACzC,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,sCAAgB,CAClC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,wBAAwB,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAO,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC7F,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAM,SAAS,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,SAAS,EAAE;gBACb,OAAO,SAAS,CAAC,MAAM,CAAC;aACzB;YACD,gGAAgG;YAChG,WAAW;YACX,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,2CAA2C,CAAC,CAAC,CAAC;YACxF,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;QAED,uCAAqB,GAArB,UAAsB,IAAsB;YAC1C,IAAM,KAAK,GAAG,IAAI,CAAC;YACnB,oDAAoD;YACpD,kEAAkE;YAClE,gCAAgC;YAChC,OAAO;gBACL,IAAI,EAAE,WAAW;gBACjB,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,aAAa;gBACvB,IAAI,EAAE,SAAS;gBACf,SAAS,EAAE,SAAS;gBACpB,QAAQ,EAAE,KAAK;gBACf,QAAQ,EAAE,KAAK;gBACf,MAAM,EAAE,IAAI;gBACZ,UAAU,EAAE,SAAS;gBACrB,aAAa,EAAE,EAAE;gBACjB,OAAO,EAAP;oBACE,OAAO,KAAK,CAAC,KAAK,CAAC;gBACrB,CAAC;gBACD,UAAU,EAAV;oBACE,OAAO,EAAE,CAAC;gBACZ,CAAC;gBACD,eAAe,EAAf,UAAgB,MAAM;oBAEhB,OAAO,SAAS,CAAC;gBACnB,CAAC;gBACL,OAAO,EAAP,UAAQ,SAAS;oBAEX,OAAO,SAAS,CAAC;gBACnB,CAAC;gBACL,aAAa,EAAb;oBAEM,OAAO,SAAS,CAAC;gBACnB,CAAC;aACN,CAAC;QACJ,CAAC;QAED,oCAAkB,GAAlB,UAAmB,GAAkB;;;gBACnC,uDAAuD;gBACvD,KAAmB,IAAA,KAAA,iBAAA,GAAG,CAAC,WAAW,CAAA,gBAAA,4BAAE;oBAA/B,IAAM,IAAI,WAAA;oBACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;iBAClB;;;;;;;;;YACD,OAAO,IAAI,CAAC,aAAa,CAAC;QAC5B,CAAC;QAED,gCAAc,GAAd,UAAe,GAAc;YAC3B,IAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACzC,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACtC,IAAM,MAAM,GAAG,UAAU,CAAC,OAAO,CAC7B,OAAO,EAAE,GAAG,CAAC,GAAG,YAAY,2BAAgB,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;YAC9E,OAAO,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC;QAChC,CAAC;QAED,iCAAe,GAAf,UAAgB,GAAe;YAC7B,8DAA8D;YAC9D,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;QAED,mCAAiB,GAAjB,UAAkB,GAAiB;;YAAnC,mBAIC;YAHC,+DAA+D;YAC/D,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAC1B,CAAA,KAAA,IAAI,CAAC,KAAK,CAAA,CAAC,YAAY,4BAAI,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,UAAA,OAAO,IAAI,OAAA,OAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAArB,CAAqB,CAAC,GAAE,CAAC;QACzF,CAAC;QAED,iCAAe,GAAf,UAAgB,GAAe;;;gBAC7B,sDAAsD;gBACtD,KAAoB,IAAA,KAAA,iBAAA,GAAG,CAAC,MAAM,CAAA,gBAAA,4BAAE;oBAA3B,IAAM,KAAK,WAAA;oBACd,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;iBACnB;;;;;;;;;YACD,iCAAiC;YACjC,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;QAED,uCAAqB,GAArB,UAAsB,GAAqB;YACzC,uEAAuE;YACvE,QAAQ,GAAG,CAAC,KAAK,EAAE;gBACjB,KAAK,IAAI,CAAC;gBACV,KAAK,KAAK;oBACR,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,OAAO,CAAC,CAAC;gBACxD,KAAK,IAAI;oBACP,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,IAAI,CAAC,CAAC;gBACrD,KAAK,SAAS;oBACZ,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,SAAS,CAAC,CAAC;gBAC1D;oBACE,QAAQ,OAAO,GAAG,CAAC,KAAK,EAAE;wBACxB,KAAK,QAAQ;4BACX,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,MAAM,CAAC,CAAC;wBACvD,KAAK,QAAQ;4BACX,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,MAAM,CAAC,CAAC;wBACvD;4BACE,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,sBAAsB,EAAE,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;4BACrF,OAAO,IAAI,CAAC,OAAO,CAAC;qBACvB;aACJ;QACH,CAAC;QAED,iCAAe,GAAf,UAAgB,GAAe;YAC7B,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAC;QACjE,CAAC;QAED,2BAAS,GAAT,UAAU,GAAgB;YAA1B,mBAiBC;YAhBC,gGAAgG;YAChG,6FAA6F;YAC7F,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACjD,IAAI,CAAC,IAAI,EAAE;gBACT,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,aAAa,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;gBACtF,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACtC,IAAM,SAAS,GACX,IAAI,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,OAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAjB,CAAiB,CAAC,CAAC,CAAC,CAAC;YACnF,IAAI,CAAC,SAAS,EAAE;gBACd,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,2BAA2B,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;gBAClF,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,OAAO,SAAS,CAAC,MAAM,CAAC;QAC1B,CAAC;QAED,gCAAc,GAAd,UAAe,GAAc;YAC3B,sDAAsD;YACtD,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC3B,4CAA4C;YAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,OAAO,CAAC,CAAC;QACxD,CAAC;QAED,oCAAkB,GAAlB,UAAmB,GAAkB;YACnC,IAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YACpD,OAAO,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;QACvD,CAAC;QAED,mCAAiB,GAAjB,UAAkB,GAAiB;YACjC,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAC;QACnE,CAAC;QAED,oCAAkB,GAAlB,UAAmB,GAAkB;YACnC,8DAA8D;YAC9D,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;QAED,4BAAU,GAAV,UAAW,IAAW;YACpB,0CAA0C;YAC1C,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,GAAG,CAAC,CAAC;QACpD,CAAC;QAED,qCAAmB,GAAnB,UAAoB,GAAmB;YACrC,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAChG,CAAC;QAED,uCAAqB,GAArB,UAAsB,GAAqB;YACzC,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAClG,CAAC;QAED;;;;WAIG;QACK,0BAAQ,GAAhB,UAAiB,GAAQ;YACvB,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,EAAE,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACzE,CAAC;QAGD,sBAAY,4BAAO;iBAAnB;gBACE,IAAI,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAC3B,IAAI,CAAC,MAAM,EAAE;oBACX,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,GAAG,CAAC,CAAC;iBACrE;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC;;;WAAA;QAGD,sBAAY,kCAAa;iBAAzB;gBACE,IAAI,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;gBACjC,IAAI,CAAC,MAAM,EAAE;oBACX,MAAM,GAAG,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,qBAAW,CAAC,SAAS,CAAC,CAAC;iBACjF;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC;;;WAAA;QAEO,mCAAiB,GAAzB,UAA0B,YAAoB,EAAE,GAA8B;YAA9E,mBAyBC;YAxBC,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE;gBAC5B,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAM,UAAU,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;YAC/D,IAAI,CAAC,UAAU,EAAE;gBACf,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,sBAAsB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC7E,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE;gBAC1B,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;gBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,uBAAuB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9E,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAM,SAAS,GAAG,UAAU,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,OAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAjB,CAAiB,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,SAAS,EAAE;gBACd,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,2BAA2B,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;gBAClF,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,OAAO,SAAS,CAAC,MAAM,CAAC;QAC1B,CAAC;QAEO,qCAAmB,GAA3B,UAA4B,YAAoB,EAAE,GAAkC;YAClF,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE;gBAC5B,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,6DAA6D;YAC7D,IAAM,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACpD,IAAI,CAAC,MAAM,EAAE;gBACX,IAAI,YAAY,CAAC,IAAI,KAAK,WAAW,EAAE;oBACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,qCAAqC,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;iBAC7F;qBAAM,IAAI,YAAY,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,YAAY,uBAAY,EAAE;oBACxE,IAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACnC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,sCAAgB,CAClC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,6BAA6B,EAAE,QAAQ,EACzD,QAAQ,UAAK,GAAG,CAAC,IAAM,EAAK,QAAQ,UAAK,GAAG,CAAC,IAAM,CAAC,CAAC,CAAC;iBAC9D;qBAAM;oBACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,sCAAgB,CAClC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,kCAAkC,EAAE,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC;iBAC5F;gBACD,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;YACD,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;gBAClB,IAAM,SAAS,GACX,YAAY,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,MAAI,YAAY,CAAC,IAAI,MAAG,CAAC;gBACnF,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,sCAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,gCAAU,CAAC,qBAAqB,EAAE,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;aACxF;YACD,OAAO,MAAM,CAAC,IAAI,CAAC;QACrB,CAAC;QAEO,uBAAK,GAAb,UAAc,MAAc;YAC1B,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,qBAAW,CAAC,GAAG;gBAChE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACjD,CAAC;QACH,cAAC;IAAD,CAAC,AA1aD,IA0aC;IA1aY,0BAAO","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 {AST, AstVisitor, Binary, BindingPipe, Chain, Conditional, FunctionCall, ImplicitReceiver, Interpolation, KeyedRead, KeyedWrite, LiteralArray, LiteralMap, LiteralPrimitive, MethodCall, NonNullAssert, PrefixNot, PropertyRead, PropertyWrite, Quote, SafeMethodCall, SafePropertyRead} from '@angular/compiler';\n\nimport {createDiagnostic, Diagnostic} from './diagnostic_messages';\nimport {BuiltinType, Signature, Symbol, SymbolQuery, SymbolTable} from './symbols';\nimport * as ng from './types';\n\ninterface ExpressionDiagnosticsContext {\n  inEvent?: boolean;\n}\n\n// AstType calculatetype of the ast given AST element.\nexport class AstType implements AstVisitor {\n  private readonly diagnostics: ng.Diagnostic[] = [];\n\n  constructor(\n      private scope: SymbolTable, private query: SymbolQuery,\n      private context: ExpressionDiagnosticsContext, private source: string) {}\n\n  getType(ast: AST): Symbol {\n    return ast.visit(this);\n  }\n\n  getDiagnostics(ast: AST): ng.Diagnostic[] {\n    const type: Symbol = ast.visit(this);\n    if (this.context.inEvent && type.callable) {\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.callable_expression_expected_method_call));\n    }\n    return this.diagnostics;\n  }\n\n  visitBinary(ast: Binary): Symbol {\n    const getType = (ast: AST, operation: string): Symbol => {\n      const type = this.getType(ast);\n      if (type.nullable) {\n        switch (operation) {\n          case '&&':\n          case '||':\n          case '==':\n          case '!=':\n          case '===':\n          case '!==':\n            // Nullable allowed.\n            break;\n          default:\n            this.diagnostics.push(createDiagnostic(ast.span, Diagnostic.expression_might_be_null));\n            break;\n        }\n      }\n      return type;\n    };\n\n    const leftType = getType(ast.left, ast.operation);\n    const rightType = getType(ast.right, ast.operation);\n    const leftKind = this.query.getTypeKind(leftType);\n    const rightKind = this.query.getTypeKind(rightType);\n\n    // The following swtich implements operator typing similar to the\n    // type production tables in the TypeScript specification.\n    // https://github.com/Microsoft/TypeScript/blob/v1.8.10/doc/spec.md#4.19\n    const operKind = leftKind << 8 | rightKind;\n    switch (ast.operation) {\n      case '*':\n      case '/':\n      case '%':\n      case '-':\n      case '<<':\n      case '>>':\n      case '>>>':\n      case '&':\n      case '^':\n      case '|':\n        switch (operKind) {\n          case BuiltinType.Any << 8 | BuiltinType.Any:\n          case BuiltinType.Number << 8 | BuiltinType.Any:\n          case BuiltinType.Any << 8 | BuiltinType.Number:\n          case BuiltinType.Number << 8 | BuiltinType.Number:\n            return this.query.getBuiltinType(BuiltinType.Number);\n          default:\n            let errorAst = ast.left;\n            switch (leftKind) {\n              case BuiltinType.Any:\n              case BuiltinType.Number:\n                errorAst = ast.right;\n                break;\n            }\n            this.diagnostics.push(\n                createDiagnostic(errorAst.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n        }\n      case '+':\n        switch (operKind) {\n          case BuiltinType.Any << 8 | BuiltinType.Any:\n          case BuiltinType.Any << 8 | BuiltinType.Boolean:\n          case BuiltinType.Any << 8 | BuiltinType.Number:\n          case BuiltinType.Any << 8 | BuiltinType.Other:\n          case BuiltinType.Boolean << 8 | BuiltinType.Any:\n          case BuiltinType.Number << 8 | BuiltinType.Any:\n          case BuiltinType.Other << 8 | BuiltinType.Any:\n            return this.anyType;\n          case BuiltinType.Any << 8 | BuiltinType.String:\n          case BuiltinType.Boolean << 8 | BuiltinType.String:\n          case BuiltinType.Number << 8 | BuiltinType.String:\n          case BuiltinType.String << 8 | BuiltinType.Any:\n          case BuiltinType.String << 8 | BuiltinType.Boolean:\n          case BuiltinType.String << 8 | BuiltinType.Number:\n          case BuiltinType.String << 8 | BuiltinType.String:\n          case BuiltinType.String << 8 | BuiltinType.Other:\n          case BuiltinType.Other << 8 | BuiltinType.String:\n            return this.query.getBuiltinType(BuiltinType.String);\n          case BuiltinType.Number << 8 | BuiltinType.Number:\n            return this.query.getBuiltinType(BuiltinType.Number);\n          case BuiltinType.Boolean << 8 | BuiltinType.Number:\n          case BuiltinType.Other << 8 | BuiltinType.Number:\n            this.diagnostics.push(\n                createDiagnostic(ast.left.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n          case BuiltinType.Number << 8 | BuiltinType.Boolean:\n          case BuiltinType.Number << 8 | BuiltinType.Other:\n            this.diagnostics.push(\n                createDiagnostic(ast.right.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n          default:\n            this.diagnostics.push(\n                createDiagnostic(ast.span, Diagnostic.expected_a_string_or_number_type));\n            return this.anyType;\n        }\n      case '>':\n      case '<':\n      case '<=':\n      case '>=':\n      case '==':\n      case '!=':\n      case '===':\n      case '!==':\n        if (!(leftKind & rightKind) &&\n            !((leftKind | rightKind) & (BuiltinType.Null | BuiltinType.Undefined))) {\n          // Two values are comparable only if\n          //   - they have some type overlap, or\n          //   - at least one is not defined\n          this.diagnostics.push(\n              createDiagnostic(ast.span, Diagnostic.expected_operands_of_comparable_types_or_any));\n        }\n        return this.query.getBuiltinType(BuiltinType.Boolean);\n      case '&&':\n        return rightType;\n      case '||':\n        return this.query.getTypeUnion(leftType, rightType);\n    }\n\n    this.diagnostics.push(\n        createDiagnostic(ast.span, Diagnostic.unrecognized_operator, ast.operation));\n    return this.anyType;\n  }\n\n  visitChain(ast: Chain) {\n    // If we are producing diagnostics, visit the children\n    for (const expr of ast.expressions) {\n      expr.visit(this);\n    }\n    // The type of a chain is always undefined.\n    return this.query.getBuiltinType(BuiltinType.Undefined);\n  }\n\n  visitConditional(ast: Conditional) {\n    // The type of a conditional is the union of the true and false conditions.\n    ast.condition.visit(this);\n    ast.trueExp.visit(this);\n    ast.falseExp.visit(this);\n    return this.query.getTypeUnion(this.getType(ast.trueExp), this.getType(ast.falseExp));\n  }\n\n  visitFunctionCall(ast: FunctionCall) {\n    // The type of a function call is the return type of the selected signature.\n    // The signature is selected based on the types of the arguments. Angular doesn't\n    // support contextual typing of arguments so this is simpler than TypeScript's\n    // version.\n    const args = ast.args.map(arg => this.getType(arg));\n    const target = this.getType(ast.target!);\n    if (!target || !target.callable) {\n      this.diagnostics.push(createDiagnostic(\n          ast.span, Diagnostic.call_target_not_callable, this.sourceOf(ast.target!), target.name));\n      return this.anyType;\n    }\n    const signature = target.selectSignature(args);\n    if (signature) {\n      return signature.result;\n    }\n    // TODO: Consider a better error message here. See `typescript_symbols#selectSignature` for more\n    // details.\n    this.diagnostics.push(\n        createDiagnostic(ast.span, Diagnostic.unable_to_resolve_compatible_call_signature));\n    return this.anyType;\n  }\n\n  visitImplicitReceiver(_ast: ImplicitReceiver): Symbol {\n    const _this = this;\n    // Return a pseudo-symbol for the implicit receiver.\n    // The members of the implicit receiver are what is defined by the\n    // scope passed into this class.\n    return {\n      name: '$implicit',\n      kind: 'component',\n      language: 'ng-template',\n      type: undefined,\n      container: undefined,\n      callable: false,\n      nullable: false,\n      public: true,\n      definition: undefined,\n      documentation: [],\n      members(): SymbolTable {\n        return _this.scope;\n      },\n      signatures(): Signature[] {\n        return [];\n      },\n      selectSignature(_types): Signature |\n          undefined {\n            return undefined;\n          },\n      indexed(_argument): Symbol |\n          undefined {\n            return undefined;\n          },\n      typeArguments(): Symbol[] |\n          undefined {\n            return undefined;\n          },\n    };\n  }\n\n  visitInterpolation(ast: Interpolation): Symbol {\n    // If we are producing diagnostics, visit the children.\n    for (const expr of ast.expressions) {\n      expr.visit(this);\n    }\n    return this.undefinedType;\n  }\n\n  visitKeyedRead(ast: KeyedRead): Symbol {\n    const targetType = this.getType(ast.obj);\n    const keyType = this.getType(ast.key);\n    const result = targetType.indexed(\n        keyType, ast.key instanceof LiteralPrimitive ? ast.key.value : undefined);\n    return result || this.anyType;\n  }\n\n  visitKeyedWrite(ast: KeyedWrite): Symbol {\n    // The write of a type is the type of the value being written.\n    return this.getType(ast.value);\n  }\n\n  visitLiteralArray(ast: LiteralArray): Symbol {\n    // A type literal is an array type of the union of the elements\n    return this.query.getArrayType(\n        this.query.getTypeUnion(...ast.expressions.map(element => this.getType(element))));\n  }\n\n  visitLiteralMap(ast: LiteralMap): Symbol {\n    // If we are producing diagnostics, visit the children\n    for (const value of ast.values) {\n      value.visit(this);\n    }\n    // TODO: Return a composite type.\n    return this.anyType;\n  }\n\n  visitLiteralPrimitive(ast: LiteralPrimitive) {\n    // The type of a literal primitive depends on the value of the literal.\n    switch (ast.value) {\n      case true:\n      case false:\n        return this.query.getBuiltinType(BuiltinType.Boolean);\n      case null:\n        return this.query.getBuiltinType(BuiltinType.Null);\n      case undefined:\n        return this.query.getBuiltinType(BuiltinType.Undefined);\n      default:\n        switch (typeof ast.value) {\n          case 'string':\n            return this.query.getBuiltinType(BuiltinType.String);\n          case 'number':\n            return this.query.getBuiltinType(BuiltinType.Number);\n          default:\n            this.diagnostics.push(\n                createDiagnostic(ast.span, Diagnostic.unrecognized_primitive, typeof ast.value));\n            return this.anyType;\n        }\n    }\n  }\n\n  visitMethodCall(ast: MethodCall) {\n    return this.resolveMethodCall(this.getType(ast.receiver), ast);\n  }\n\n  visitPipe(ast: BindingPipe) {\n    // The type of a pipe node is the return type of the pipe's transform method. The table returned\n    // by getPipes() is expected to contain symbols with the corresponding transform method type.\n    const pipe = this.query.getPipes().get(ast.name);\n    if (!pipe) {\n      this.diagnostics.push(createDiagnostic(ast.span, Diagnostic.no_pipe_found, ast.name));\n      return this.anyType;\n    }\n    const expType = this.getType(ast.exp);\n    const signature =\n        pipe.selectSignature([expType].concat(ast.args.map(arg => this.getType(arg))));\n    if (!signature) {\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.unable_to_resolve_signature, ast.name));\n      return this.anyType;\n    }\n    return signature.result;\n  }\n\n  visitPrefixNot(ast: PrefixNot) {\n    // If we are producing diagnostics, visit the children\n    ast.expression.visit(this);\n    // The type of a prefix ! is always boolean.\n    return this.query.getBuiltinType(BuiltinType.Boolean);\n  }\n\n  visitNonNullAssert(ast: NonNullAssert) {\n    const expressionType = this.getType(ast.expression);\n    return this.query.getNonNullableType(expressionType);\n  }\n\n  visitPropertyRead(ast: PropertyRead) {\n    return this.resolvePropertyRead(this.getType(ast.receiver), ast);\n  }\n\n  visitPropertyWrite(ast: PropertyWrite) {\n    // The type of a write is the type of the value being written.\n    return this.getType(ast.value);\n  }\n\n  visitQuote(_ast: Quote) {\n    // The type of a quoted expression is any.\n    return this.query.getBuiltinType(BuiltinType.Any);\n  }\n\n  visitSafeMethodCall(ast: SafeMethodCall) {\n    return this.resolveMethodCall(this.query.getNonNullableType(this.getType(ast.receiver)), ast);\n  }\n\n  visitSafePropertyRead(ast: SafePropertyRead) {\n    return this.resolvePropertyRead(this.query.getNonNullableType(this.getType(ast.receiver)), ast);\n  }\n\n  /**\n   * Gets the source of an expession AST.\n   * The AST's sourceSpan is relative to the start of the template source code, which is contained\n   * at this.source.\n   */\n  private sourceOf(ast: AST): string {\n    return this.source.substring(ast.sourceSpan.start, ast.sourceSpan.end);\n  }\n\n  private _anyType: Symbol|undefined;\n  private get anyType(): Symbol {\n    let result = this._anyType;\n    if (!result) {\n      result = this._anyType = this.query.getBuiltinType(BuiltinType.Any);\n    }\n    return result;\n  }\n\n  private _undefinedType: Symbol|undefined;\n  private get undefinedType(): Symbol {\n    let result = this._undefinedType;\n    if (!result) {\n      result = this._undefinedType = this.query.getBuiltinType(BuiltinType.Undefined);\n    }\n    return result;\n  }\n\n  private resolveMethodCall(receiverType: Symbol, ast: SafeMethodCall|MethodCall) {\n    if (this.isAny(receiverType)) {\n      return this.anyType;\n    }\n    const methodType = this.resolvePropertyRead(receiverType, ast);\n    if (!methodType) {\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.could_not_resolve_type, ast.name));\n      return this.anyType;\n    }\n    if (this.isAny(methodType)) {\n      return this.anyType;\n    }\n    if (!methodType.callable) {\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.identifier_not_callable, ast.name));\n      return this.anyType;\n    }\n    const signature = methodType.selectSignature(ast.args.map(arg => this.getType(arg)));\n    if (!signature) {\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.unable_to_resolve_signature, ast.name));\n      return this.anyType;\n    }\n    return signature.result;\n  }\n\n  private resolvePropertyRead(receiverType: Symbol, ast: SafePropertyRead|PropertyRead) {\n    if (this.isAny(receiverType)) {\n      return this.anyType;\n    }\n    // The type of a property read is the seelcted member's type.\n    const member = receiverType.members().get(ast.name);\n    if (!member) {\n      if (receiverType.name === '$implicit') {\n        this.diagnostics.push(\n            createDiagnostic(ast.span, Diagnostic.identifier_not_defined_in_app_context, ast.name));\n      } else if (receiverType.nullable && ast.receiver instanceof PropertyRead) {\n        const receiver = ast.receiver.name;\n        this.diagnostics.push(createDiagnostic(\n            ast.span, Diagnostic.identifier_possibly_undefined, receiver,\n            `${receiver}?.${ast.name}`, `${receiver}!.${ast.name}`));\n      } else {\n        this.diagnostics.push(createDiagnostic(\n            ast.span, Diagnostic.identifier_not_defined_on_receiver, ast.name, receiverType.name));\n      }\n      return this.anyType;\n    }\n    if (!member.public) {\n      const container =\n          receiverType.name === '$implicit' ? 'the component' : `'${receiverType.name}'`;\n      this.diagnostics.push(\n          createDiagnostic(ast.span, Diagnostic.identifier_is_private, ast.name, container));\n    }\n    return member.type;\n  }\n\n  private isAny(symbol: Symbol): boolean {\n    return !symbol || this.query.getTypeKind(symbol) === BuiltinType.Any ||\n        (!!symbol.type && this.isAny(symbol.type));\n  }\n}\n"]}
457
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expression_type.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expression_type.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 {AST, AstVisitor, ASTWithName, Binary, BindingPipe, Chain, Conditional, FunctionCall, ImplicitReceiver, Interpolation, KeyedRead, KeyedWrite, LiteralArray, LiteralMap, LiteralPrimitive, MethodCall, NonNullAssert, PrefixNot, PropertyRead, PropertyWrite, Quote, SafeMethodCall, SafePropertyRead} from '@angular/compiler';\n\nimport {createDiagnostic, Diagnostic} from './diagnostic_messages';\nimport {BuiltinType, Signature, Symbol, SymbolQuery, SymbolTable} from './symbols';\nimport * as ng from './types';\nimport {offsetSpan} from './utils';\n\ninterface ExpressionDiagnosticsContext {\n  inEvent?: boolean;\n}\n\n// AstType calculatetype of the ast given AST element.\nexport class AstType implements AstVisitor {\n  private readonly diagnostics: ng.Diagnostic[] = [];\n\n  constructor(\n      private scope: SymbolTable, private query: SymbolQuery,\n      private context: ExpressionDiagnosticsContext, private source: string) {}\n\n  getType(ast: AST): Symbol {\n    return ast.visit(this);\n  }\n\n  getDiagnostics(ast: AST): ng.Diagnostic[] {\n    const type: Symbol = ast.visit(this);\n    if (this.context.inEvent && type.callable) {\n      this.diagnostics.push(\n          createDiagnostic(refinedSpan(ast), Diagnostic.callable_expression_expected_method_call));\n    }\n    return this.diagnostics;\n  }\n\n  visitBinary(ast: Binary): Symbol {\n    const getType = (ast: AST, operation: string): Symbol => {\n      const type = this.getType(ast);\n      if (type.nullable) {\n        switch (operation) {\n          case '&&':\n          case '||':\n          case '==':\n          case '!=':\n          case '===':\n          case '!==':\n            // Nullable allowed.\n            break;\n          default:\n            this.diagnostics.push(\n                createDiagnostic(refinedSpan(ast), Diagnostic.expression_might_be_null));\n            break;\n        }\n      }\n      return type;\n    };\n\n    const leftType = getType(ast.left, ast.operation);\n    const rightType = getType(ast.right, ast.operation);\n    const leftKind = this.query.getTypeKind(leftType);\n    const rightKind = this.query.getTypeKind(rightType);\n\n    // The following swtich implements operator typing similar to the\n    // type production tables in the TypeScript specification.\n    // https://github.com/Microsoft/TypeScript/blob/v1.8.10/doc/spec.md#4.19\n    const operKind = leftKind << 8 | rightKind;\n    switch (ast.operation) {\n      case '*':\n      case '/':\n      case '%':\n      case '-':\n      case '<<':\n      case '>>':\n      case '>>>':\n      case '&':\n      case '^':\n      case '|':\n        switch (operKind) {\n          case BuiltinType.Any << 8 | BuiltinType.Any:\n          case BuiltinType.Number << 8 | BuiltinType.Any:\n          case BuiltinType.Any << 8 | BuiltinType.Number:\n          case BuiltinType.Number << 8 | BuiltinType.Number:\n            return this.query.getBuiltinType(BuiltinType.Number);\n          default:\n            let errorAst = ast.left;\n            switch (leftKind) {\n              case BuiltinType.Any:\n              case BuiltinType.Number:\n                errorAst = ast.right;\n                break;\n            }\n            this.diagnostics.push(\n                createDiagnostic(errorAst.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n        }\n      case '+':\n        switch (operKind) {\n          case BuiltinType.Any << 8 | BuiltinType.Any:\n          case BuiltinType.Any << 8 | BuiltinType.Boolean:\n          case BuiltinType.Any << 8 | BuiltinType.Number:\n          case BuiltinType.Any << 8 | BuiltinType.Other:\n          case BuiltinType.Boolean << 8 | BuiltinType.Any:\n          case BuiltinType.Number << 8 | BuiltinType.Any:\n          case BuiltinType.Other << 8 | BuiltinType.Any:\n            return this.anyType;\n          case BuiltinType.Any << 8 | BuiltinType.String:\n          case BuiltinType.Boolean << 8 | BuiltinType.String:\n          case BuiltinType.Number << 8 | BuiltinType.String:\n          case BuiltinType.String << 8 | BuiltinType.Any:\n          case BuiltinType.String << 8 | BuiltinType.Boolean:\n          case BuiltinType.String << 8 | BuiltinType.Number:\n          case BuiltinType.String << 8 | BuiltinType.String:\n          case BuiltinType.String << 8 | BuiltinType.Other:\n          case BuiltinType.Other << 8 | BuiltinType.String:\n            return this.query.getBuiltinType(BuiltinType.String);\n          case BuiltinType.Number << 8 | BuiltinType.Number:\n            return this.query.getBuiltinType(BuiltinType.Number);\n          case BuiltinType.Boolean << 8 | BuiltinType.Number:\n          case BuiltinType.Other << 8 | BuiltinType.Number:\n            this.diagnostics.push(\n                createDiagnostic(ast.left.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n          case BuiltinType.Number << 8 | BuiltinType.Boolean:\n          case BuiltinType.Number << 8 | BuiltinType.Other:\n            this.diagnostics.push(\n                createDiagnostic(ast.right.span, Diagnostic.expected_a_number_type));\n            return this.anyType;\n          default:\n            this.diagnostics.push(\n                createDiagnostic(refinedSpan(ast), Diagnostic.expected_a_string_or_number_type));\n            return this.anyType;\n        }\n      case '>':\n      case '<':\n      case '<=':\n      case '>=':\n      case '==':\n      case '!=':\n      case '===':\n      case '!==':\n        if (!(leftKind & rightKind) &&\n            !((leftKind | rightKind) & (BuiltinType.Null | BuiltinType.Undefined))) {\n          // Two values are comparable only if\n          //   - they have some type overlap, or\n          //   - at least one is not defined\n          this.diagnostics.push(createDiagnostic(\n              refinedSpan(ast), Diagnostic.expected_operands_of_comparable_types_or_any));\n        }\n        return this.query.getBuiltinType(BuiltinType.Boolean);\n      case '&&':\n        return rightType;\n      case '||':\n        return this.query.getTypeUnion(leftType, rightType);\n    }\n\n    this.diagnostics.push(\n        createDiagnostic(refinedSpan(ast), Diagnostic.unrecognized_operator, ast.operation));\n    return this.anyType;\n  }\n\n  visitChain(ast: Chain) {\n    // If we are producing diagnostics, visit the children\n    for (const expr of ast.expressions) {\n      expr.visit(this);\n    }\n    // The type of a chain is always undefined.\n    return this.query.getBuiltinType(BuiltinType.Undefined);\n  }\n\n  visitConditional(ast: Conditional) {\n    // The type of a conditional is the union of the true and false conditions.\n    ast.condition.visit(this);\n    ast.trueExp.visit(this);\n    ast.falseExp.visit(this);\n    return this.query.getTypeUnion(this.getType(ast.trueExp), this.getType(ast.falseExp));\n  }\n\n  visitFunctionCall(ast: FunctionCall) {\n    // The type of a function call is the return type of the selected signature.\n    // The signature is selected based on the types of the arguments. Angular doesn't\n    // support contextual typing of arguments so this is simpler than TypeScript's\n    // version.\n    const args = ast.args.map(arg => this.getType(arg));\n    const target = this.getType(ast.target!);\n    if (!target || !target.callable) {\n      this.diagnostics.push(createDiagnostic(\n          refinedSpan(ast), Diagnostic.call_target_not_callable, this.sourceOf(ast.target!),\n          target.name));\n      return this.anyType;\n    }\n    const signature = target.selectSignature(args);\n    if (signature) {\n      return signature.result;\n    }\n    // TODO: Consider a better error message here. See `typescript_symbols#selectSignature` for more\n    // details.\n    this.diagnostics.push(\n        createDiagnostic(refinedSpan(ast), Diagnostic.unable_to_resolve_compatible_call_signature));\n    return this.anyType;\n  }\n\n  visitImplicitReceiver(_ast: ImplicitReceiver): Symbol {\n    const _this = this;\n    // Return a pseudo-symbol for the implicit receiver.\n    // The members of the implicit receiver are what is defined by the\n    // scope passed into this class.\n    return {\n      name: '$implicit',\n      kind: 'component',\n      language: 'ng-template',\n      type: undefined,\n      container: undefined,\n      callable: false,\n      nullable: false,\n      public: true,\n      definition: undefined,\n      documentation: [],\n      members(): SymbolTable {\n        return _this.scope;\n      },\n      signatures(): Signature[] {\n        return [];\n      },\n      selectSignature(_types): Signature |\n          undefined {\n            return undefined;\n          },\n      indexed(_argument): Symbol |\n          undefined {\n            return undefined;\n          },\n      typeArguments(): Symbol[] |\n          undefined {\n            return undefined;\n          },\n    };\n  }\n\n  visitInterpolation(ast: Interpolation): Symbol {\n    // If we are producing diagnostics, visit the children.\n    for (const expr of ast.expressions) {\n      expr.visit(this);\n    }\n    return this.undefinedType;\n  }\n\n  visitKeyedRead(ast: KeyedRead): Symbol {\n    const targetType = this.getType(ast.obj);\n    const keyType = this.getType(ast.key);\n    const result = targetType.indexed(\n        keyType, ast.key instanceof LiteralPrimitive ? ast.key.value : undefined);\n    return result || this.anyType;\n  }\n\n  visitKeyedWrite(ast: KeyedWrite): Symbol {\n    // The write of a type is the type of the value being written.\n    return this.getType(ast.value);\n  }\n\n  visitLiteralArray(ast: LiteralArray): Symbol {\n    // A type literal is an array type of the union of the elements\n    return this.query.getArrayType(\n        this.query.getTypeUnion(...ast.expressions.map(element => this.getType(element))));\n  }\n\n  visitLiteralMap(ast: LiteralMap): Symbol {\n    // If we are producing diagnostics, visit the children\n    for (const value of ast.values) {\n      value.visit(this);\n    }\n    // TODO: Return a composite type.\n    return this.anyType;\n  }\n\n  visitLiteralPrimitive(ast: LiteralPrimitive) {\n    // The type of a literal primitive depends on the value of the literal.\n    switch (ast.value) {\n      case true:\n      case false:\n        return this.query.getBuiltinType(BuiltinType.Boolean);\n      case null:\n        return this.query.getBuiltinType(BuiltinType.Null);\n      case undefined:\n        return this.query.getBuiltinType(BuiltinType.Undefined);\n      default:\n        switch (typeof ast.value) {\n          case 'string':\n            return this.query.getBuiltinType(BuiltinType.String);\n          case 'number':\n            return this.query.getBuiltinType(BuiltinType.Number);\n          default:\n            this.diagnostics.push(createDiagnostic(\n                refinedSpan(ast), Diagnostic.unrecognized_primitive, typeof ast.value));\n            return this.anyType;\n        }\n    }\n  }\n\n  visitMethodCall(ast: MethodCall) {\n    return this.resolveMethodCall(this.getType(ast.receiver), ast);\n  }\n\n  visitPipe(ast: BindingPipe) {\n    // The type of a pipe node is the return type of the pipe's transform method. The table returned\n    // by getPipes() is expected to contain symbols with the corresponding transform method type.\n    const pipe = this.query.getPipes().get(ast.name);\n    if (!pipe) {\n      this.diagnostics.push(createDiagnostic(refinedSpan(ast), Diagnostic.no_pipe_found, ast.name));\n      return this.anyType;\n    }\n    const expType = this.getType(ast.exp);\n    const signature =\n        pipe.selectSignature([expType].concat(ast.args.map(arg => this.getType(arg))));\n    if (!signature) {\n      this.diagnostics.push(\n          createDiagnostic(refinedSpan(ast), Diagnostic.unable_to_resolve_signature, ast.name));\n      return this.anyType;\n    }\n    return signature.result;\n  }\n\n  visitPrefixNot(ast: PrefixNot) {\n    // If we are producing diagnostics, visit the children\n    ast.expression.visit(this);\n    // The type of a prefix ! is always boolean.\n    return this.query.getBuiltinType(BuiltinType.Boolean);\n  }\n\n  visitNonNullAssert(ast: NonNullAssert) {\n    const expressionType = this.getType(ast.expression);\n    return this.query.getNonNullableType(expressionType);\n  }\n\n  visitPropertyRead(ast: PropertyRead) {\n    return this.resolvePropertyRead(this.getType(ast.receiver), ast);\n  }\n\n  visitPropertyWrite(ast: PropertyWrite) {\n    // The type of a write is the type of the value being written.\n    return this.getType(ast.value);\n  }\n\n  visitQuote(_ast: Quote) {\n    // The type of a quoted expression is any.\n    return this.query.getBuiltinType(BuiltinType.Any);\n  }\n\n  visitSafeMethodCall(ast: SafeMethodCall) {\n    return this.resolveMethodCall(this.query.getNonNullableType(this.getType(ast.receiver)), ast);\n  }\n\n  visitSafePropertyRead(ast: SafePropertyRead) {\n    return this.resolvePropertyRead(this.query.getNonNullableType(this.getType(ast.receiver)), ast);\n  }\n\n  /**\n   * Gets the source of an expession AST.\n   * The AST's sourceSpan is relative to the start of the template source code, which is contained\n   * at this.source.\n   */\n  private sourceOf(ast: AST): string {\n    return this.source.substring(ast.sourceSpan.start, ast.sourceSpan.end);\n  }\n\n  private _anyType: Symbol|undefined;\n  private get anyType(): Symbol {\n    let result = this._anyType;\n    if (!result) {\n      result = this._anyType = this.query.getBuiltinType(BuiltinType.Any);\n    }\n    return result;\n  }\n\n  private _undefinedType: Symbol|undefined;\n  private get undefinedType(): Symbol {\n    let result = this._undefinedType;\n    if (!result) {\n      result = this._undefinedType = this.query.getBuiltinType(BuiltinType.Undefined);\n    }\n    return result;\n  }\n\n  private resolveMethodCall(receiverType: Symbol, ast: SafeMethodCall|MethodCall) {\n    if (this.isAny(receiverType)) {\n      return this.anyType;\n    }\n    const methodType = this.resolvePropertyRead(receiverType, ast);\n    if (!methodType) {\n      this.diagnostics.push(\n          createDiagnostic(refinedSpan(ast), Diagnostic.could_not_resolve_type, ast.name));\n      return this.anyType;\n    }\n    if (this.isAny(methodType)) {\n      return this.anyType;\n    }\n    if (!methodType.callable) {\n      this.diagnostics.push(\n          createDiagnostic(refinedSpan(ast), Diagnostic.identifier_not_callable, ast.name));\n      return this.anyType;\n    }\n    const signature = methodType.selectSignature(ast.args.map(arg => this.getType(arg)));\n    if (!signature) {\n      this.diagnostics.push(\n          createDiagnostic(refinedSpan(ast), Diagnostic.unable_to_resolve_signature, ast.name));\n      return this.anyType;\n    }\n    return signature.result;\n  }\n\n  private resolvePropertyRead(receiverType: Symbol, ast: SafePropertyRead|PropertyRead) {\n    if (this.isAny(receiverType)) {\n      return this.anyType;\n    }\n    // The type of a property read is the seelcted member's type.\n    const member = receiverType.members().get(ast.name);\n    if (!member) {\n      if (receiverType.name === '$implicit') {\n        this.diagnostics.push(createDiagnostic(\n            refinedSpan(ast), Diagnostic.identifier_not_defined_in_app_context, ast.name));\n      } else if (receiverType.nullable && ast.receiver instanceof PropertyRead) {\n        const receiver = ast.receiver.name;\n        this.diagnostics.push(createDiagnostic(\n            refinedSpan(ast), Diagnostic.identifier_possibly_undefined, receiver,\n            `${receiver}?.${ast.name}`, `${receiver}!.${ast.name}`));\n      } else {\n        this.diagnostics.push(createDiagnostic(\n            refinedSpan(ast), Diagnostic.identifier_not_defined_on_receiver, ast.name,\n            receiverType.name));\n      }\n      return this.anyType;\n    }\n    if (!member.public) {\n      const container =\n          receiverType.name === '$implicit' ? 'the component' : `'${receiverType.name}'`;\n      this.diagnostics.push(createDiagnostic(\n          refinedSpan(ast), Diagnostic.identifier_is_private, ast.name, container));\n    }\n    return member.type;\n  }\n\n  private isAny(symbol: Symbol): boolean {\n    return !symbol || this.query.getTypeKind(symbol) === BuiltinType.Any ||\n        (!!symbol.type && this.isAny(symbol.type));\n  }\n}\n\nfunction refinedSpan(ast: AST): ng.Span {\n  // nameSpan is an absolute span, but the spans returned by the expression visitor are expected to\n  // be relative to the start of the expression.\n  // TODO: migrate to only using absolute spans\n  const absoluteOffset = ast.sourceSpan.start - ast.span.start;\n  if (ast instanceof ASTWithName) {\n    return offsetSpan(ast.nameSpan, -absoluteOffset);\n  }\n  return offsetSpan(ast.sourceSpan, -absoluteOffset);\n}\n"]}
@@ -122,6 +122,16 @@
122
122
  function getType(ast) {
123
123
  return new expression_type_1.AstType(scope, templateInfo.query, {}, templateInfo.source).getType(ast);
124
124
  }
125
+ function spanFromName(ast) {
126
+ // `nameSpan` is an absolute span, but the span expected by the result of this method is
127
+ // relative to the start of the expression.
128
+ // TODO(ayazhafiz): migrate to only using absolute spans
129
+ var offset = ast.sourceSpan.start - ast.span.start;
130
+ return {
131
+ start: ast.nameSpan.start - offset,
132
+ end: ast.nameSpan.end - offset,
133
+ };
134
+ }
125
135
  var symbol = undefined;
126
136
  var span = undefined;
127
137
  // If the completion request is in a not in a pipe or property access then the global scope
@@ -142,21 +152,14 @@
142
152
  visitMethodCall: function (ast) {
143
153
  var receiverType = getType(ast.receiver);
144
154
  symbol = receiverType && receiverType.members().get(ast.name);
145
- span = ast.span;
155
+ span = spanFromName(ast);
146
156
  },
147
157
  visitPipe: function (ast) {
148
158
  if (utils_1.inSpan(position, ast.nameSpan, /* exclusive */ true)) {
149
159
  // We are in a position a pipe name is expected.
150
160
  var pipes = templateInfo.query.getPipes();
151
161
  symbol = pipes.get(ast.name);
152
- // `nameSpan` is an absolute span, but the span expected by the result of this method is
153
- // relative to the start of the expression.
154
- // TODO(ayazhafiz): migrate to only using absolute spans
155
- var offset = ast.sourceSpan.start - ast.span.start;
156
- span = {
157
- start: ast.nameSpan.start - offset,
158
- end: ast.nameSpan.end - offset,
159
- };
162
+ span = spanFromName(ast);
160
163
  }
161
164
  },
162
165
  visitPrefixNot: function (_ast) { },
@@ -164,29 +167,23 @@
164
167
  visitPropertyRead: function (ast) {
165
168
  var receiverType = getType(ast.receiver);
166
169
  symbol = receiverType && receiverType.members().get(ast.name);
167
- span = ast.span;
170
+ span = spanFromName(ast);
168
171
  },
169
172
  visitPropertyWrite: function (ast) {
170
173
  var receiverType = getType(ast.receiver);
171
- var start = ast.span.start;
172
174
  symbol = receiverType && receiverType.members().get(ast.name);
173
- // A PropertyWrite span includes both the LHS (name) and the RHS (value) of the write. In this
174
- // visit, only the name is relevant.
175
- // prop=$event
176
- // ^^^^ name
177
- // ^^^^^^ value; visited separately as a nested AST
178
- span = { start: start, end: start + ast.name.length };
175
+ span = spanFromName(ast);
179
176
  },
180
177
  visitQuote: function (_ast) { },
181
178
  visitSafeMethodCall: function (ast) {
182
179
  var receiverType = getType(ast.receiver);
183
180
  symbol = receiverType && receiverType.members().get(ast.name);
184
- span = ast.span;
181
+ span = spanFromName(ast);
185
182
  },
186
183
  visitSafePropertyRead: function (ast) {
187
184
  var receiverType = getType(ast.receiver);
188
185
  symbol = receiverType && receiverType.members().get(ast.name);
189
- span = ast.span;
186
+ span = spanFromName(ast);
190
187
  },
191
188
  });
192
189
  if (symbol && span) {
@@ -195,4 +192,4 @@
195
192
  }
196
193
  exports.getExpressionSymbol = getExpressionSymbol;
197
194
  });
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expressions.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 {AST, AstPath as AstPathBase, ASTWithSource, RecursiveAstVisitor} from '@angular/compiler';\n\nimport {AstType} from './expression_type';\nimport {BuiltinType, Span, Symbol, SymbolTable, TemplateSource} from './types';\nimport {inSpan} from './utils';\n\ntype AstPath = AstPathBase<AST>;\n\nfunction findAstAt(ast: AST, position: number, excludeEmpty: boolean = false): AstPath {\n  const path: AST[] = [];\n  const visitor = new class extends RecursiveAstVisitor {\n    visit(ast: AST) {\n      if ((!excludeEmpty || ast.sourceSpan.start < ast.sourceSpan.end) &&\n          inSpan(position, ast.sourceSpan)) {\n        path.push(ast);\n        ast.visit(this);\n      }\n    }\n  };\n\n  // We never care about the ASTWithSource node and its visit() method calls its ast's visit so\n  // the visit() method above would never see it.\n  if (ast instanceof ASTWithSource) {\n    ast = ast.ast;\n  }\n\n  visitor.visit(ast);\n\n  return new AstPathBase<AST>(path, position);\n}\n\nexport function getExpressionCompletions(\n    scope: SymbolTable, ast: AST, position: number, templateInfo: TemplateSource): Symbol[]|\n    undefined {\n  const path = findAstAt(ast, position);\n  if (path.empty) return undefined;\n  const tail = path.tail!;\n  let result: SymbolTable|undefined = scope;\n\n  function getType(ast: AST): Symbol {\n    return new AstType(scope, templateInfo.query, {}, templateInfo.source).getType(ast);\n  }\n\n  // If the completion request is in a not in a pipe or property access then the global scope\n  // (that is the scope of the implicit receiver) is the right scope as the user is typing the\n  // beginning of an expression.\n  tail.visit({\n    visitBinary(_ast) {},\n    visitChain(_ast) {},\n    visitConditional(_ast) {},\n    visitFunctionCall(_ast) {},\n    visitImplicitReceiver(_ast) {},\n    visitInterpolation(_ast) {\n      result = undefined;\n    },\n    visitKeyedRead(_ast) {},\n    visitKeyedWrite(_ast) {},\n    visitLiteralArray(_ast) {},\n    visitLiteralMap(_ast) {},\n    visitLiteralPrimitive(_ast) {},\n    visitMethodCall(_ast) {},\n    visitPipe(ast) {\n      if (position >= ast.exp.span.end &&\n          (!ast.args || !ast.args.length || position < (<AST>ast.args[0]).span.start)) {\n        // We are in a position a pipe name is expected.\n        result = templateInfo.query.getPipes();\n      }\n    },\n    visitPrefixNot(_ast) {},\n    visitNonNullAssert(_ast) {},\n    visitPropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitPropertyWrite(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitQuote(_ast) {\n      // For a quote, return the members of any (if there are any).\n      result = templateInfo.query.getBuiltinType(BuiltinType.Any).members();\n    },\n    visitSafeMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitSafePropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n  });\n\n  return result && result.values();\n}\n\n/**\n * Retrieves the expression symbol at a particular position in a template.\n *\n * @param scope symbols in scope of the template\n * @param ast template AST\n * @param position absolute location in template to retrieve symbol at\n * @param query type symbol query for the template scope\n */\nexport function getExpressionSymbol(\n    scope: SymbolTable, ast: AST, position: number,\n    templateInfo: TemplateSource): {symbol: Symbol, span: Span}|undefined {\n  const path = findAstAt(ast, position, /* excludeEmpty */ true);\n  if (path.empty) return undefined;\n  const tail = path.tail!;\n\n  function getType(ast: AST): Symbol {\n    return new AstType(scope, templateInfo.query, {}, templateInfo.source).getType(ast);\n  }\n\n  let symbol: Symbol|undefined = undefined;\n  let span: Span|undefined = undefined;\n\n  // If the completion request is in a not in a pipe or property access then the global scope\n  // (that is the scope of the implicit receiver) is the right scope as the user is typing the\n  // beginning of an expression.\n  tail.visit({\n    visitBinary(_ast) {},\n    visitChain(_ast) {},\n    visitConditional(_ast) {},\n    visitFunctionCall(_ast) {},\n    visitImplicitReceiver(_ast) {},\n    visitInterpolation(_ast) {},\n    visitKeyedRead(_ast) {},\n    visitKeyedWrite(_ast) {},\n    visitLiteralArray(_ast) {},\n    visitLiteralMap(_ast) {},\n    visitLiteralPrimitive(_ast) {},\n    visitMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = ast.span;\n    },\n    visitPipe(ast) {\n      if (inSpan(position, ast.nameSpan, /* exclusive */ true)) {\n        // We are in a position a pipe name is expected.\n        const pipes = templateInfo.query.getPipes();\n        symbol = pipes.get(ast.name);\n\n        // `nameSpan` is an absolute span, but the span expected by the result of this method is\n        // relative to the start of the expression.\n        // TODO(ayazhafiz): migrate to only using absolute spans\n        const offset = ast.sourceSpan.start - ast.span.start;\n        span = {\n          start: ast.nameSpan.start - offset,\n          end: ast.nameSpan.end - offset,\n        };\n      }\n    },\n    visitPrefixNot(_ast) {},\n    visitNonNullAssert(_ast) {},\n    visitPropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = ast.span;\n    },\n    visitPropertyWrite(ast) {\n      const receiverType = getType(ast.receiver);\n      const {start} = ast.span;\n      symbol = receiverType && receiverType.members().get(ast.name);\n      // A PropertyWrite span includes both the LHS (name) and the RHS (value) of the write. In this\n      // visit, only the name is relevant.\n      //   prop=$event\n      //   ^^^^        name\n      //        ^^^^^^ value; visited separately as a nested AST\n      span = {start, end: start + ast.name.length};\n    },\n    visitQuote(_ast) {},\n    visitSafeMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = ast.span;\n    },\n    visitSafePropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = ast.span;\n    },\n  });\n\n  if (symbol && span) {\n    return {symbol, span};\n  }\n}\n"]}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/expressions.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 {AST, AstPath as AstPathBase, ASTWithName, ASTWithSource, RecursiveAstVisitor} from '@angular/compiler';\n\nimport {AstType} from './expression_type';\nimport {BuiltinType, Span, Symbol, SymbolTable, TemplateSource} from './types';\nimport {inSpan} from './utils';\n\ntype AstPath = AstPathBase<AST>;\n\nfunction findAstAt(ast: AST, position: number, excludeEmpty: boolean = false): AstPath {\n  const path: AST[] = [];\n  const visitor = new class extends RecursiveAstVisitor {\n    visit(ast: AST) {\n      if ((!excludeEmpty || ast.sourceSpan.start < ast.sourceSpan.end) &&\n          inSpan(position, ast.sourceSpan)) {\n        path.push(ast);\n        ast.visit(this);\n      }\n    }\n  };\n\n  // We never care about the ASTWithSource node and its visit() method calls its ast's visit so\n  // the visit() method above would never see it.\n  if (ast instanceof ASTWithSource) {\n    ast = ast.ast;\n  }\n\n  visitor.visit(ast);\n\n  return new AstPathBase<AST>(path, position);\n}\n\nexport function getExpressionCompletions(\n    scope: SymbolTable, ast: AST, position: number, templateInfo: TemplateSource): Symbol[]|\n    undefined {\n  const path = findAstAt(ast, position);\n  if (path.empty) return undefined;\n  const tail = path.tail!;\n  let result: SymbolTable|undefined = scope;\n\n  function getType(ast: AST): Symbol {\n    return new AstType(scope, templateInfo.query, {}, templateInfo.source).getType(ast);\n  }\n\n  // If the completion request is in a not in a pipe or property access then the global scope\n  // (that is the scope of the implicit receiver) is the right scope as the user is typing the\n  // beginning of an expression.\n  tail.visit({\n    visitBinary(_ast) {},\n    visitChain(_ast) {},\n    visitConditional(_ast) {},\n    visitFunctionCall(_ast) {},\n    visitImplicitReceiver(_ast) {},\n    visitInterpolation(_ast) {\n      result = undefined;\n    },\n    visitKeyedRead(_ast) {},\n    visitKeyedWrite(_ast) {},\n    visitLiteralArray(_ast) {},\n    visitLiteralMap(_ast) {},\n    visitLiteralPrimitive(_ast) {},\n    visitMethodCall(_ast) {},\n    visitPipe(ast) {\n      if (position >= ast.exp.span.end &&\n          (!ast.args || !ast.args.length || position < (<AST>ast.args[0]).span.start)) {\n        // We are in a position a pipe name is expected.\n        result = templateInfo.query.getPipes();\n      }\n    },\n    visitPrefixNot(_ast) {},\n    visitNonNullAssert(_ast) {},\n    visitPropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitPropertyWrite(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitQuote(_ast) {\n      // For a quote, return the members of any (if there are any).\n      result = templateInfo.query.getBuiltinType(BuiltinType.Any).members();\n    },\n    visitSafeMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n    visitSafePropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      result = receiverType ? receiverType.members() : scope;\n    },\n  });\n\n  return result && result.values();\n}\n\n/**\n * Retrieves the expression symbol at a particular position in a template.\n *\n * @param scope symbols in scope of the template\n * @param ast template AST\n * @param position absolute location in template to retrieve symbol at\n * @param query type symbol query for the template scope\n */\nexport function getExpressionSymbol(\n    scope: SymbolTable, ast: AST, position: number,\n    templateInfo: TemplateSource): {symbol: Symbol, span: Span}|undefined {\n  const path = findAstAt(ast, position, /* excludeEmpty */ true);\n  if (path.empty) return undefined;\n  const tail = path.tail!;\n\n  function getType(ast: AST): Symbol {\n    return new AstType(scope, templateInfo.query, {}, templateInfo.source).getType(ast);\n  }\n\n  function spanFromName(ast: ASTWithName): Span {\n    // `nameSpan` is an absolute span, but the span expected by the result of this method is\n    // relative to the start of the expression.\n    // TODO(ayazhafiz): migrate to only using absolute spans\n    const offset = ast.sourceSpan.start - ast.span.start;\n    return {\n      start: ast.nameSpan.start - offset,\n      end: ast.nameSpan.end - offset,\n    };\n  }\n\n  let symbol: Symbol|undefined = undefined;\n  let span: Span|undefined = undefined;\n\n  // If the completion request is in a not in a pipe or property access then the global scope\n  // (that is the scope of the implicit receiver) is the right scope as the user is typing the\n  // beginning of an expression.\n  tail.visit({\n    visitBinary(_ast) {},\n    visitChain(_ast) {},\n    visitConditional(_ast) {},\n    visitFunctionCall(_ast) {},\n    visitImplicitReceiver(_ast) {},\n    visitInterpolation(_ast) {},\n    visitKeyedRead(_ast) {},\n    visitKeyedWrite(_ast) {},\n    visitLiteralArray(_ast) {},\n    visitLiteralMap(_ast) {},\n    visitLiteralPrimitive(_ast) {},\n    visitMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = spanFromName(ast);\n    },\n    visitPipe(ast) {\n      if (inSpan(position, ast.nameSpan, /* exclusive */ true)) {\n        // We are in a position a pipe name is expected.\n        const pipes = templateInfo.query.getPipes();\n        symbol = pipes.get(ast.name);\n        span = spanFromName(ast);\n      }\n    },\n    visitPrefixNot(_ast) {},\n    visitNonNullAssert(_ast) {},\n    visitPropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = spanFromName(ast);\n    },\n    visitPropertyWrite(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = spanFromName(ast);\n    },\n    visitQuote(_ast) {},\n    visitSafeMethodCall(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = spanFromName(ast);\n    },\n    visitSafePropertyRead(ast) {\n      const receiverType = getType(ast.receiver);\n      symbol = receiverType && receiverType.members().get(ast.name);\n      span = spanFromName(ast);\n    },\n  });\n\n  if (symbol && span) {\n    return {symbol, span};\n  }\n}\n"]}
@@ -0,0 +1,71 @@
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
+ */
8
+ /// <amd-module name="@angular/language-service/src/ts_utils" />
9
+ import * as ts from 'typescript/lib/tsserverlibrary';
10
+ /**
11
+ * Return the node that most tightly encompass the specified `position`.
12
+ * @param node
13
+ * @param position
14
+ */
15
+ export declare function findTightestNode(node: ts.Node, position: number): ts.Node | undefined;
16
+ /**
17
+ * Returns a property assignment from the assignment value if the property name
18
+ * matches the specified `key`, or `undefined` if there is no match.
19
+ */
20
+ export declare function getPropertyAssignmentFromValue(value: ts.Node, key: string): ts.PropertyAssignment | undefined;
21
+ /**
22
+ * Given a decorator property assignment, return the ClassDeclaration node that corresponds to the
23
+ * directive class the property applies to.
24
+ * If the property assignment is not on a class decorator, no declaration is returned.
25
+ *
26
+ * For example,
27
+ *
28
+ * @Component({
29
+ * template: '<div></div>'
30
+ * ^^^^^^^^^^^^^^^^^^^^^^^---- property assignment
31
+ * })
32
+ * class AppComponent {}
33
+ * ^---- class declaration node
34
+ *
35
+ * @param propAsgn property assignment
36
+ */
37
+ export declare function getClassDeclFromDecoratorProp(propAsgnNode: ts.PropertyAssignment): ts.ClassDeclaration | undefined;
38
+ interface DirectiveClassLike {
39
+ decoratorId: ts.Identifier;
40
+ classId: ts.Identifier;
41
+ }
42
+ /**
43
+ * Return metadata about `node` if it looks like an Angular directive class.
44
+ * In this case, potential matches are `@NgModule`, `@Component`, `@Directive`,
45
+ * `@Pipe`, etc.
46
+ * These class declarations all share some common attributes, namely their
47
+ * decorator takes exactly one parameter and the parameter must be an object
48
+ * literal.
49
+ *
50
+ * For example,
51
+ * v---------- `decoratorId`
52
+ * @NgModule({ <
53
+ * declarations: [], < classDecl
54
+ * }) <
55
+ * class AppModule {} <
56
+ * ^----- `classId`
57
+ *
58
+ * @param node Potential node that represents an Angular directive.
59
+ */
60
+ export declare function getDirectiveClassLike(node: ts.Node): DirectiveClassLike | undefined;
61
+ /**
62
+ * Finds the value of a property assignment that is nested in a TypeScript node and is of a certain
63
+ * type T.
64
+ *
65
+ * @param startNode node to start searching for nested property assignment from
66
+ * @param propName property assignment name
67
+ * @param predicate function to verify that a node is of type T.
68
+ * @return node property assignment value of type T, or undefined if none is found
69
+ */
70
+ export declare function findPropertyValueOfType<T extends ts.Node>(startNode: ts.Node, propName: string, predicate: (node: ts.Node) => node is T): T | undefined;
71
+ export {};