@angular/language-service 11.1.0-next.5 → 11.1.2

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/ivy/utils.js CHANGED
@@ -4,12 +4,12 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/language-service/ivy/utils", ["require", "exports", "tslib", "@angular/compiler", "@angular/compiler-cli/src/ngtsc/metadata", "@angular/compiler/src/expression_parser/ast", "@angular/compiler/src/render3/r3_ast", "typescript", "@angular/language-service/ivy/display_parts", "@angular/language-service/ivy/ts_utils"], factory);
7
+ define("@angular/language-service/ivy/utils", ["require", "exports", "tslib", "@angular/compiler", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/metadata", "@angular/compiler/src/expression_parser/ast", "@angular/compiler/src/render3/r3_ast", "typescript", "@angular/language-service/ivy/display_parts", "@angular/language-service/ivy/ts_utils"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.isWithin = exports.isExternalTemplate = exports.isTypeScriptFile = exports.flatMap = exports.isDollarEvent = exports.filterAliasImports = exports.getDirectiveMatchesForAttribute = exports.makeElementSelector = exports.getDirectiveMatchesForElementTag = exports.getTemplateInfoAtPosition = exports.isExpressionNode = exports.isTemplateNode = exports.isWithinKeyValue = exports.isWithinKey = exports.isTemplateNodeWithKeyAndValue = exports.toTextSpan = exports.getTextSpanOfNode = void 0;
12
+ exports.getTemplateLocationFromShimLocation = exports.isWithin = exports.isExternalTemplate = exports.isTypeScriptFile = exports.flatMap = exports.isDollarEvent = exports.filterAliasImports = exports.getDirectiveMatchesForAttribute = exports.makeElementSelector = exports.getDirectiveMatchesForElementTag = exports.getTemplateInfoAtPosition = exports.isExpressionNode = exports.isTemplateNode = exports.isWithinKeyValue = exports.isWithinKey = exports.isTemplateNodeWithKeyAndValue = exports.toTextSpan = exports.getTextSpanOfNode = void 0;
13
13
  var tslib_1 = require("tslib");
14
14
  /**
15
15
  * @license
@@ -19,6 +19,7 @@
19
19
  * found in the LICENSE file at https://angular.io/license
20
20
  */
21
21
  var compiler_1 = require("@angular/compiler");
22
+ var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
22
23
  var metadata_1 = require("@angular/compiler-cli/src/ngtsc/metadata");
23
24
  var e = require("@angular/compiler/src/expression_parser/ast"); // e for expression AST
24
25
  var t = require("@angular/compiler/src/render3/r3_ast"); // t for template AST
@@ -351,5 +352,31 @@
351
352
  return start <= position && position <= end;
352
353
  }
353
354
  exports.isWithin = isWithin;
355
+ /**
356
+ * For a given location in a shim file, retrieves the corresponding file url for the template and
357
+ * the span in the template.
358
+ */
359
+ function getTemplateLocationFromShimLocation(templateTypeChecker, shimPath, positionInShimFile) {
360
+ var mapping = templateTypeChecker.getTemplateMappingAtShimLocation({ shimPath: shimPath, positionInShimFile: positionInShimFile });
361
+ if (mapping === null) {
362
+ return null;
363
+ }
364
+ var templateSourceMapping = mapping.templateSourceMapping, span = mapping.span;
365
+ var templateUrl;
366
+ if (templateSourceMapping.type === 'direct') {
367
+ templateUrl = file_system_1.absoluteFromSourceFile(templateSourceMapping.node.getSourceFile());
368
+ }
369
+ else if (templateSourceMapping.type === 'external') {
370
+ templateUrl = file_system_1.absoluteFrom(templateSourceMapping.templateUrl);
371
+ }
372
+ else {
373
+ // This includes indirect mappings, which are difficult to map directly to the code
374
+ // location. Diagnostics similarly return a synthetic template string for this case rather
375
+ // than a real location.
376
+ return null;
377
+ }
378
+ return { templateUrl: templateUrl, span: span };
379
+ }
380
+ exports.getTemplateLocationFromShimLocation = getTemplateLocationFromShimLocation;
354
381
  });
355
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {AbsoluteSourceSpan, CssSelector, ParseSourceSpan, SelectorMatcher, TmplAstBoundEvent} from '@angular/compiler';\nimport {NgCompiler} from '@angular/compiler-cli/src/ngtsc/core';\nimport {isExternalResource} from '@angular/compiler-cli/src/ngtsc/metadata';\nimport {DeclarationNode} from '@angular/compiler-cli/src/ngtsc/reflection';\nimport {DirectiveSymbol} from '@angular/compiler-cli/src/ngtsc/typecheck/api';\nimport {Diagnostic as ngDiagnostic, isNgDiagnostic} from '@angular/compiler-cli/src/transformers/api';\nimport * as e from '@angular/compiler/src/expression_parser/ast';  // e for expression AST\nimport * as t from '@angular/compiler/src/render3/r3_ast';         // t for template AST\nimport * as ts from 'typescript';\n\nimport {ALIAS_NAME, SYMBOL_PUNC} from './display_parts';\nimport {findTightestNode, getParentClassDeclaration} from './ts_utils';\n\nexport function getTextSpanOfNode(node: t.Node|e.AST): ts.TextSpan {\n  if (isTemplateNodeWithKeyAndValue(node)) {\n    return toTextSpan(node.keySpan);\n  } else if (\n      node instanceof e.PropertyWrite || node instanceof e.MethodCall ||\n      node instanceof e.BindingPipe || node instanceof e.PropertyRead) {\n    // The `name` part of a `PropertyWrite`, `MethodCall`, and `BindingPipe` does not\n    // have its own AST so there is no way to retrieve a `Symbol` for just the `name` via a specific\n    // node.\n    return toTextSpan(node.nameSpan);\n  } else {\n    return toTextSpan(node.sourceSpan);\n  }\n}\n\nexport function toTextSpan(span: AbsoluteSourceSpan|ParseSourceSpan): ts.TextSpan {\n  let start: number, end: number;\n  if (span instanceof AbsoluteSourceSpan) {\n    start = span.start;\n    end = span.end;\n  } else {\n    start = span.start.offset;\n    end = span.end.offset;\n  }\n  return {start, length: end - start};\n}\n\ninterface NodeWithKeyAndValue extends t.Node {\n  keySpan: ParseSourceSpan;\n  valueSpan?: ParseSourceSpan;\n}\n\nexport function isTemplateNodeWithKeyAndValue(node: t.Node|e.AST): node is NodeWithKeyAndValue {\n  return isTemplateNode(node) && node.hasOwnProperty('keySpan');\n}\n\nexport function isWithinKey(position: number, node: NodeWithKeyAndValue): boolean {\n  let {keySpan, valueSpan} = node;\n  if (valueSpan === undefined && node instanceof TmplAstBoundEvent) {\n    valueSpan = node.handlerSpan;\n  }\n  const isWithinKeyValue =\n      isWithin(position, keySpan) || !!(valueSpan && isWithin(position, valueSpan));\n  return isWithinKeyValue;\n}\n\nexport function isWithinKeyValue(position: number, node: NodeWithKeyAndValue): boolean {\n  let {keySpan, valueSpan} = node;\n  if (valueSpan === undefined && node instanceof TmplAstBoundEvent) {\n    valueSpan = node.handlerSpan;\n  }\n  const isWithinKeyValue =\n      isWithin(position, keySpan) || !!(valueSpan && isWithin(position, valueSpan));\n  return isWithinKeyValue;\n}\n\nexport function isTemplateNode(node: t.Node|e.AST): node is t.Node {\n  // Template node implements the Node interface so we cannot use instanceof.\n  return node.sourceSpan instanceof ParseSourceSpan;\n}\n\nexport function isExpressionNode(node: t.Node|e.AST): node is e.AST {\n  return node instanceof e.AST;\n}\n\nexport interface TemplateInfo {\n  template: t.Node[];\n  component: ts.ClassDeclaration;\n}\n\nfunction getInlineTemplateInfoAtPosition(\n    sf: ts.SourceFile, position: number, compiler: NgCompiler): TemplateInfo|undefined {\n  const expression = findTightestNode(sf, position);\n  if (expression === undefined) {\n    return undefined;\n  }\n  const classDecl = getParentClassDeclaration(expression);\n  if (classDecl === undefined) {\n    return undefined;\n  }\n\n  // Return `undefined` if the position is not on the template expression or the template resource\n  // is not inline.\n  const resources = compiler.getComponentResources(classDecl);\n  if (resources === null || isExternalResource(resources.template) ||\n      expression !== resources.template.expression) {\n    return undefined;\n  }\n\n  const template = compiler.getTemplateTypeChecker().getTemplate(classDecl);\n  if (template === null) {\n    return undefined;\n  }\n\n  return {template, component: classDecl};\n}\n\n/**\n * Retrieves the `ts.ClassDeclaration` at a location along with its template nodes.\n */\nexport function getTemplateInfoAtPosition(\n    fileName: string, position: number, compiler: NgCompiler): TemplateInfo|undefined {\n  if (isTypeScriptFile(fileName)) {\n    const sf = compiler.getNextProgram().getSourceFile(fileName);\n    if (sf === undefined) {\n      return undefined;\n    }\n\n    return getInlineTemplateInfoAtPosition(sf, position, compiler);\n  } else {\n    return getFirstComponentForTemplateFile(fileName, compiler);\n  }\n}\n\n/**\n * First, attempt to sort component declarations by file name.\n * If the files are the same, sort by start location of the declaration.\n */\nfunction tsDeclarationSortComparator(a: DeclarationNode, b: DeclarationNode): number {\n  const aFile = a.getSourceFile().fileName;\n  const bFile = b.getSourceFile().fileName;\n  if (aFile < bFile) {\n    return -1;\n  } else if (aFile > bFile) {\n    return 1;\n  } else {\n    return b.getFullStart() - a.getFullStart();\n  }\n}\n\nfunction getFirstComponentForTemplateFile(fileName: string, compiler: NgCompiler): TemplateInfo|\n    undefined {\n  const templateTypeChecker = compiler.getTemplateTypeChecker();\n  const components = compiler.getComponentsWithTemplateFile(fileName);\n  const sortedComponents = Array.from(components).sort(tsDeclarationSortComparator);\n  for (const component of sortedComponents) {\n    if (!ts.isClassDeclaration(component)) {\n      continue;\n    }\n    const template = templateTypeChecker.getTemplate(component);\n    if (template === null) {\n      continue;\n    }\n    return {template, component};\n  }\n\n  return undefined;\n}\n\n/**\n * Given an attribute node, converts it to string form.\n */\nfunction toAttributeString(attribute: t.TextAttribute|t.BoundAttribute|t.BoundEvent): string {\n  if (attribute instanceof t.BoundEvent) {\n    return `[${attribute.name}]`;\n  } else {\n    return `[${attribute.name}=${attribute.valueSpan?.toString() ?? ''}]`;\n  }\n}\n\nfunction getNodeName(node: t.Template|t.Element): string {\n  return node instanceof t.Template ? node.tagName : node.name;\n}\n\n/**\n * Given a template or element node, returns all attributes on the node.\n */\nfunction getAttributes(node: t.Template|\n                       t.Element): Array<t.TextAttribute|t.BoundAttribute|t.BoundEvent> {\n  const attributes: Array<t.TextAttribute|t.BoundAttribute|t.BoundEvent> =\n      [...node.attributes, ...node.inputs, ...node.outputs];\n  if (node instanceof t.Template) {\n    attributes.push(...node.templateAttrs);\n  }\n  return attributes;\n}\n\n/**\n * Given two `Set`s, returns all items in the `left` which do not appear in the `right`.\n */\nfunction difference<T>(left: Set<T>, right: Set<T>): Set<T> {\n  const result = new Set<T>();\n  for (const dir of left) {\n    if (!right.has(dir)) {\n      result.add(dir);\n    }\n  }\n  return result;\n}\n\n/**\n * Given an element or template, determines which directives match because the tag is present. For\n * example, if a directive selector is `div[myAttr]`, this would match div elements but would not if\n * the selector were just `[myAttr]`. We find which directives are applied because of this tag by\n * elimination: compare the directive matches with the tag present against the directive matches\n * without it. The difference would be the directives which match because the tag is present.\n *\n * @param element The element or template node that the attribute/tag is part of.\n * @param directives The list of directives to match against.\n * @returns The list of directives matching the tag name via the strategy described above.\n */\n// TODO(atscott): Add unit tests for this and the one for attributes\nexport function getDirectiveMatchesForElementTag(\n    element: t.Template|t.Element, directives: DirectiveSymbol[]): Set<DirectiveSymbol> {\n  const attributes = getAttributes(element);\n  const allAttrs = attributes.map(toAttributeString);\n  const allDirectiveMatches =\n      getDirectiveMatchesForSelector(directives, getNodeName(element) + allAttrs.join(''));\n  const matchesWithoutElement = getDirectiveMatchesForSelector(directives, allAttrs.join(''));\n  return difference(allDirectiveMatches, matchesWithoutElement);\n}\n\n\nexport function makeElementSelector(element: t.Element|t.Template): string {\n  const attributes = getAttributes(element);\n  const allAttrs = attributes.map(toAttributeString);\n  return getNodeName(element) + allAttrs.join('');\n}\n\n/**\n * Given an attribute name, determines which directives match because the attribute is present. We\n * find which directives are applied because of this attribute by elimination: compare the directive\n * matches with the attribute present against the directive matches without it. The difference would\n * be the directives which match because the attribute is present.\n *\n * @param name The name of the attribute\n * @param hostNode The node which the attribute appears on\n * @param directives The list of directives to match against.\n * @returns The list of directives matching the tag name via the strategy described above.\n */\nexport function getDirectiveMatchesForAttribute(\n    name: string, hostNode: t.Template|t.Element,\n    directives: DirectiveSymbol[]): Set<DirectiveSymbol> {\n  const attributes = getAttributes(hostNode);\n  const allAttrs = attributes.map(toAttributeString);\n  const allDirectiveMatches =\n      getDirectiveMatchesForSelector(directives, getNodeName(hostNode) + allAttrs.join(''));\n  const attrsExcludingName = attributes.filter(a => a.name !== name).map(toAttributeString);\n  const matchesWithoutAttr = getDirectiveMatchesForSelector(\n      directives, getNodeName(hostNode) + attrsExcludingName.join(''));\n  return difference(allDirectiveMatches, matchesWithoutAttr);\n}\n\n/**\n * Given a list of directives and a text to use as a selector, returns the directives which match\n * for the selector.\n */\nfunction getDirectiveMatchesForSelector(\n    directives: DirectiveSymbol[], selector: string): Set<DirectiveSymbol> {\n  const selectors = CssSelector.parse(selector);\n  if (selectors.length === 0) {\n    return new Set();\n  }\n  return new Set(directives.filter((dir: DirectiveSymbol) => {\n    if (dir.selector === null) {\n      return false;\n    }\n\n    const matcher = new SelectorMatcher();\n    matcher.addSelectables(CssSelector.parse(dir.selector));\n\n    return selectors.some(selector => matcher.match(selector, null));\n  }));\n}\n\n/**\n * Returns a new `ts.SymbolDisplayPart` array which has the alias imports from the tcb filtered\n * out, i.e. `i0.NgForOf`.\n */\nexport function filterAliasImports(displayParts: ts.SymbolDisplayPart[]): ts.SymbolDisplayPart[] {\n  const tcbAliasImportRegex = /i\\d+/;\n  function isImportAlias(part: {kind: string, text: string}) {\n    return part.kind === ALIAS_NAME && tcbAliasImportRegex.test(part.text);\n  }\n  function isDotPunctuation(part: {kind: string, text: string}) {\n    return part.kind === SYMBOL_PUNC && part.text === '.';\n  }\n\n  return displayParts.filter((part, i) => {\n    const previousPart = displayParts[i - 1];\n    const nextPart = displayParts[i + 1];\n\n    const aliasNameFollowedByDot =\n        isImportAlias(part) && nextPart !== undefined && isDotPunctuation(nextPart);\n    const dotPrecededByAlias =\n        isDotPunctuation(part) && previousPart !== undefined && isImportAlias(previousPart);\n\n    return !aliasNameFollowedByDot && !dotPrecededByAlias;\n  });\n}\n\nexport function isDollarEvent(n: t.Node|e.AST): n is e.PropertyRead {\n  return n instanceof e.PropertyRead && n.name === '$event' &&\n      n.receiver instanceof e.ImplicitReceiver && !(n.receiver instanceof e.ThisReceiver);\n}\n\n/**\n * Returns a new array formed by applying a given callback function to each element of the array,\n * and then flattening the result by one level.\n */\nexport function flatMap<T, R>(items: T[]|readonly T[], f: (item: T) => R[] | readonly R[]): R[] {\n  const results: R[] = [];\n  for (const x of items) {\n    results.push(...f(x));\n  }\n  return results;\n}\n\nexport function isTypeScriptFile(fileName: string): boolean {\n  return fileName.endsWith('.ts');\n}\n\nexport function isExternalTemplate(fileName: string): boolean {\n  return !isTypeScriptFile(fileName);\n}\n\nexport function isWithin(position: number, span: AbsoluteSourceSpan|ParseSourceSpan): boolean {\n  let start: number, end: number;\n  if (span instanceof ParseSourceSpan) {\n    start = span.start.offset;\n    end = span.end.offset;\n  } else {\n    start = span.start;\n    end = span.end;\n  }\n  // Note both start and end are inclusive because we want to match conditions\n  // like ¦start and end¦ where ¦ is the cursor.\n  return start <= position && position <= end;\n}\n"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {AbsoluteSourceSpan, CssSelector, ParseSourceSpan, SelectorMatcher, TmplAstBoundEvent} from '@angular/compiler';\nimport {NgCompiler} from '@angular/compiler-cli/src/ngtsc/core';\nimport {absoluteFrom, absoluteFromSourceFile, AbsoluteFsPath} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {isExternalResource} from '@angular/compiler-cli/src/ngtsc/metadata';\nimport {DeclarationNode} from '@angular/compiler-cli/src/ngtsc/reflection';\nimport {DirectiveSymbol, TemplateTypeChecker} from '@angular/compiler-cli/src/ngtsc/typecheck/api';\nimport * as e from '@angular/compiler/src/expression_parser/ast';  // e for expression AST\nimport * as t from '@angular/compiler/src/render3/r3_ast';         // t for template AST\nimport * as ts from 'typescript';\n\nimport {ALIAS_NAME, SYMBOL_PUNC} from './display_parts';\nimport {findTightestNode, getParentClassDeclaration} from './ts_utils';\n\nexport function getTextSpanOfNode(node: t.Node|e.AST): ts.TextSpan {\n  if (isTemplateNodeWithKeyAndValue(node)) {\n    return toTextSpan(node.keySpan);\n  } else if (\n      node instanceof e.PropertyWrite || node instanceof e.MethodCall ||\n      node instanceof e.BindingPipe || node instanceof e.PropertyRead) {\n    // The `name` part of a `PropertyWrite`, `MethodCall`, and `BindingPipe` does not\n    // have its own AST so there is no way to retrieve a `Symbol` for just the `name` via a specific\n    // node.\n    return toTextSpan(node.nameSpan);\n  } else {\n    return toTextSpan(node.sourceSpan);\n  }\n}\n\nexport function toTextSpan(span: AbsoluteSourceSpan|ParseSourceSpan): ts.TextSpan {\n  let start: number, end: number;\n  if (span instanceof AbsoluteSourceSpan) {\n    start = span.start;\n    end = span.end;\n  } else {\n    start = span.start.offset;\n    end = span.end.offset;\n  }\n  return {start, length: end - start};\n}\n\ninterface NodeWithKeyAndValue extends t.Node {\n  keySpan: ParseSourceSpan;\n  valueSpan?: ParseSourceSpan;\n}\n\nexport function isTemplateNodeWithKeyAndValue(node: t.Node|e.AST): node is NodeWithKeyAndValue {\n  return isTemplateNode(node) && node.hasOwnProperty('keySpan');\n}\n\nexport function isWithinKey(position: number, node: NodeWithKeyAndValue): boolean {\n  let {keySpan, valueSpan} = node;\n  if (valueSpan === undefined && node instanceof TmplAstBoundEvent) {\n    valueSpan = node.handlerSpan;\n  }\n  const isWithinKeyValue =\n      isWithin(position, keySpan) || !!(valueSpan && isWithin(position, valueSpan));\n  return isWithinKeyValue;\n}\n\nexport function isWithinKeyValue(position: number, node: NodeWithKeyAndValue): boolean {\n  let {keySpan, valueSpan} = node;\n  if (valueSpan === undefined && node instanceof TmplAstBoundEvent) {\n    valueSpan = node.handlerSpan;\n  }\n  const isWithinKeyValue =\n      isWithin(position, keySpan) || !!(valueSpan && isWithin(position, valueSpan));\n  return isWithinKeyValue;\n}\n\nexport function isTemplateNode(node: t.Node|e.AST): node is t.Node {\n  // Template node implements the Node interface so we cannot use instanceof.\n  return node.sourceSpan instanceof ParseSourceSpan;\n}\n\nexport function isExpressionNode(node: t.Node|e.AST): node is e.AST {\n  return node instanceof e.AST;\n}\n\nexport interface TemplateInfo {\n  template: t.Node[];\n  component: ts.ClassDeclaration;\n}\n\nfunction getInlineTemplateInfoAtPosition(\n    sf: ts.SourceFile, position: number, compiler: NgCompiler): TemplateInfo|undefined {\n  const expression = findTightestNode(sf, position);\n  if (expression === undefined) {\n    return undefined;\n  }\n  const classDecl = getParentClassDeclaration(expression);\n  if (classDecl === undefined) {\n    return undefined;\n  }\n\n  // Return `undefined` if the position is not on the template expression or the template resource\n  // is not inline.\n  const resources = compiler.getComponentResources(classDecl);\n  if (resources === null || isExternalResource(resources.template) ||\n      expression !== resources.template.expression) {\n    return undefined;\n  }\n\n  const template = compiler.getTemplateTypeChecker().getTemplate(classDecl);\n  if (template === null) {\n    return undefined;\n  }\n\n  return {template, component: classDecl};\n}\n\n/**\n * Retrieves the `ts.ClassDeclaration` at a location along with its template nodes.\n */\nexport function getTemplateInfoAtPosition(\n    fileName: string, position: number, compiler: NgCompiler): TemplateInfo|undefined {\n  if (isTypeScriptFile(fileName)) {\n    const sf = compiler.getNextProgram().getSourceFile(fileName);\n    if (sf === undefined) {\n      return undefined;\n    }\n\n    return getInlineTemplateInfoAtPosition(sf, position, compiler);\n  } else {\n    return getFirstComponentForTemplateFile(fileName, compiler);\n  }\n}\n\n/**\n * First, attempt to sort component declarations by file name.\n * If the files are the same, sort by start location of the declaration.\n */\nfunction tsDeclarationSortComparator(a: DeclarationNode, b: DeclarationNode): number {\n  const aFile = a.getSourceFile().fileName;\n  const bFile = b.getSourceFile().fileName;\n  if (aFile < bFile) {\n    return -1;\n  } else if (aFile > bFile) {\n    return 1;\n  } else {\n    return b.getFullStart() - a.getFullStart();\n  }\n}\n\nfunction getFirstComponentForTemplateFile(fileName: string, compiler: NgCompiler): TemplateInfo|\n    undefined {\n  const templateTypeChecker = compiler.getTemplateTypeChecker();\n  const components = compiler.getComponentsWithTemplateFile(fileName);\n  const sortedComponents = Array.from(components).sort(tsDeclarationSortComparator);\n  for (const component of sortedComponents) {\n    if (!ts.isClassDeclaration(component)) {\n      continue;\n    }\n    const template = templateTypeChecker.getTemplate(component);\n    if (template === null) {\n      continue;\n    }\n    return {template, component};\n  }\n\n  return undefined;\n}\n\n/**\n * Given an attribute node, converts it to string form.\n */\nfunction toAttributeString(attribute: t.TextAttribute|t.BoundAttribute|t.BoundEvent): string {\n  if (attribute instanceof t.BoundEvent) {\n    return `[${attribute.name}]`;\n  } else {\n    return `[${attribute.name}=${attribute.valueSpan?.toString() ?? ''}]`;\n  }\n}\n\nfunction getNodeName(node: t.Template|t.Element): string {\n  return node instanceof t.Template ? node.tagName : node.name;\n}\n\n/**\n * Given a template or element node, returns all attributes on the node.\n */\nfunction getAttributes(node: t.Template|\n                       t.Element): Array<t.TextAttribute|t.BoundAttribute|t.BoundEvent> {\n  const attributes: Array<t.TextAttribute|t.BoundAttribute|t.BoundEvent> =\n      [...node.attributes, ...node.inputs, ...node.outputs];\n  if (node instanceof t.Template) {\n    attributes.push(...node.templateAttrs);\n  }\n  return attributes;\n}\n\n/**\n * Given two `Set`s, returns all items in the `left` which do not appear in the `right`.\n */\nfunction difference<T>(left: Set<T>, right: Set<T>): Set<T> {\n  const result = new Set<T>();\n  for (const dir of left) {\n    if (!right.has(dir)) {\n      result.add(dir);\n    }\n  }\n  return result;\n}\n\n/**\n * Given an element or template, determines which directives match because the tag is present. For\n * example, if a directive selector is `div[myAttr]`, this would match div elements but would not if\n * the selector were just `[myAttr]`. We find which directives are applied because of this tag by\n * elimination: compare the directive matches with the tag present against the directive matches\n * without it. The difference would be the directives which match because the tag is present.\n *\n * @param element The element or template node that the attribute/tag is part of.\n * @param directives The list of directives to match against.\n * @returns The list of directives matching the tag name via the strategy described above.\n */\n// TODO(atscott): Add unit tests for this and the one for attributes\nexport function getDirectiveMatchesForElementTag(\n    element: t.Template|t.Element, directives: DirectiveSymbol[]): Set<DirectiveSymbol> {\n  const attributes = getAttributes(element);\n  const allAttrs = attributes.map(toAttributeString);\n  const allDirectiveMatches =\n      getDirectiveMatchesForSelector(directives, getNodeName(element) + allAttrs.join(''));\n  const matchesWithoutElement = getDirectiveMatchesForSelector(directives, allAttrs.join(''));\n  return difference(allDirectiveMatches, matchesWithoutElement);\n}\n\n\nexport function makeElementSelector(element: t.Element|t.Template): string {\n  const attributes = getAttributes(element);\n  const allAttrs = attributes.map(toAttributeString);\n  return getNodeName(element) + allAttrs.join('');\n}\n\n/**\n * Given an attribute name, determines which directives match because the attribute is present. We\n * find which directives are applied because of this attribute by elimination: compare the directive\n * matches with the attribute present against the directive matches without it. The difference would\n * be the directives which match because the attribute is present.\n *\n * @param name The name of the attribute\n * @param hostNode The node which the attribute appears on\n * @param directives The list of directives to match against.\n * @returns The list of directives matching the tag name via the strategy described above.\n */\nexport function getDirectiveMatchesForAttribute(\n    name: string, hostNode: t.Template|t.Element,\n    directives: DirectiveSymbol[]): Set<DirectiveSymbol> {\n  const attributes = getAttributes(hostNode);\n  const allAttrs = attributes.map(toAttributeString);\n  const allDirectiveMatches =\n      getDirectiveMatchesForSelector(directives, getNodeName(hostNode) + allAttrs.join(''));\n  const attrsExcludingName = attributes.filter(a => a.name !== name).map(toAttributeString);\n  const matchesWithoutAttr = getDirectiveMatchesForSelector(\n      directives, getNodeName(hostNode) + attrsExcludingName.join(''));\n  return difference(allDirectiveMatches, matchesWithoutAttr);\n}\n\n/**\n * Given a list of directives and a text to use as a selector, returns the directives which match\n * for the selector.\n */\nfunction getDirectiveMatchesForSelector(\n    directives: DirectiveSymbol[], selector: string): Set<DirectiveSymbol> {\n  const selectors = CssSelector.parse(selector);\n  if (selectors.length === 0) {\n    return new Set();\n  }\n  return new Set(directives.filter((dir: DirectiveSymbol) => {\n    if (dir.selector === null) {\n      return false;\n    }\n\n    const matcher = new SelectorMatcher();\n    matcher.addSelectables(CssSelector.parse(dir.selector));\n\n    return selectors.some(selector => matcher.match(selector, null));\n  }));\n}\n\n/**\n * Returns a new `ts.SymbolDisplayPart` array which has the alias imports from the tcb filtered\n * out, i.e. `i0.NgForOf`.\n */\nexport function filterAliasImports(displayParts: ts.SymbolDisplayPart[]): ts.SymbolDisplayPart[] {\n  const tcbAliasImportRegex = /i\\d+/;\n  function isImportAlias(part: {kind: string, text: string}) {\n    return part.kind === ALIAS_NAME && tcbAliasImportRegex.test(part.text);\n  }\n  function isDotPunctuation(part: {kind: string, text: string}) {\n    return part.kind === SYMBOL_PUNC && part.text === '.';\n  }\n\n  return displayParts.filter((part, i) => {\n    const previousPart = displayParts[i - 1];\n    const nextPart = displayParts[i + 1];\n\n    const aliasNameFollowedByDot =\n        isImportAlias(part) && nextPart !== undefined && isDotPunctuation(nextPart);\n    const dotPrecededByAlias =\n        isDotPunctuation(part) && previousPart !== undefined && isImportAlias(previousPart);\n\n    return !aliasNameFollowedByDot && !dotPrecededByAlias;\n  });\n}\n\nexport function isDollarEvent(n: t.Node|e.AST): n is e.PropertyRead {\n  return n instanceof e.PropertyRead && n.name === '$event' &&\n      n.receiver instanceof e.ImplicitReceiver && !(n.receiver instanceof e.ThisReceiver);\n}\n\n/**\n * Returns a new array formed by applying a given callback function to each element of the array,\n * and then flattening the result by one level.\n */\nexport function flatMap<T, R>(items: T[]|readonly T[], f: (item: T) => R[] | readonly R[]): R[] {\n  const results: R[] = [];\n  for (const x of items) {\n    results.push(...f(x));\n  }\n  return results;\n}\n\nexport function isTypeScriptFile(fileName: string): boolean {\n  return fileName.endsWith('.ts');\n}\n\nexport function isExternalTemplate(fileName: string): boolean {\n  return !isTypeScriptFile(fileName);\n}\n\nexport function isWithin(position: number, span: AbsoluteSourceSpan|ParseSourceSpan): boolean {\n  let start: number, end: number;\n  if (span instanceof ParseSourceSpan) {\n    start = span.start.offset;\n    end = span.end.offset;\n  } else {\n    start = span.start;\n    end = span.end;\n  }\n  // Note both start and end are inclusive because we want to match conditions\n  // like ¦start and end¦ where ¦ is the cursor.\n  return start <= position && position <= end;\n}\n\n/**\n * For a given location in a shim file, retrieves the corresponding file url for the template and\n * the span in the template.\n */\nexport function getTemplateLocationFromShimLocation(\n    templateTypeChecker: TemplateTypeChecker, shimPath: AbsoluteFsPath,\n    positionInShimFile: number): {templateUrl: AbsoluteFsPath, span: ParseSourceSpan}|null {\n  const mapping =\n      templateTypeChecker.getTemplateMappingAtShimLocation({shimPath, positionInShimFile});\n  if (mapping === null) {\n    return null;\n  }\n  const {templateSourceMapping, span} = mapping;\n\n  let templateUrl: AbsoluteFsPath;\n  if (templateSourceMapping.type === 'direct') {\n    templateUrl = absoluteFromSourceFile(templateSourceMapping.node.getSourceFile());\n  } else if (templateSourceMapping.type === 'external') {\n    templateUrl = absoluteFrom(templateSourceMapping.templateUrl);\n  } else {\n    // This includes indirect mappings, which are difficult to map directly to the code\n    // location. Diagnostics similarly return a synthetic template string for this case rather\n    // than a real location.\n    return null;\n  }\n  return {templateUrl, span};\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/language-service",
3
- "version": "11.1.0-next.5",
3
+ "version": "11.1.2",
4
4
  "description": "Angular - language services",
5
5
  "main": "./bundles/language-service.js",
6
6
  "typings": "./index.d.ts",
@@ -122,4 +122,4 @@
122
122
  return LanguageServiceImpl;
123
123
  }());
124
124
  });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language_service.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/language_service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as path from 'path';\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {getTemplateCompletions} from './completions';\nimport {getDefinitionAndBoundSpan, getTsDefinitionAndBoundSpan} from './definitions';\nimport {getDeclarationDiagnostics, getTemplateDiagnostics, ngDiagnosticToTsDiagnostic} from './diagnostics';\nimport {getTemplateHover, getTsHover} from './hover';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n/**\n * Create an instance of an Angular `LanguageService`.\n *\n * @publicApi\n */\nexport function createLanguageService(host: TypeScriptServiceHost) {\n  return new LanguageServiceImpl(host);\n}\n\nclass LanguageServiceImpl implements ng.LanguageService {\n  constructor(private readonly host: TypeScriptServiceHost) {}\n\n  getSemanticDiagnostics(fileName: string): tss.Diagnostic[] {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ngDiagnostics: ng.Diagnostic[] = [];\n\n    const templates = this.host.getTemplates(fileName);\n    for (const template of templates) {\n      const ast = this.host.getTemplateAst(template);\n      if (ast) {\n        ngDiagnostics.push(...getTemplateDiagnostics(ast));\n      }\n    }\n\n    const declarations = this.host.getDeclarations(fileName);\n    ngDiagnostics.push(...getDeclarationDiagnostics(declarations, analyzedModules, this.host));\n\n    const sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;\n    const tsDiagnostics = ngDiagnostics.map(d => ngDiagnosticToTsDiagnostic(d, sourceFile));\n    return [...tss.sortAndDeduplicateDiagnostics(tsDiagnostics)];\n  }\n\n  getCompletionsAtPosition(\n      fileName: string, position: number,\n      _options?: tss.GetCompletionsAtPositionOptions): tss.CompletionInfo|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ast = this.host.getTemplateAstAtPosition(fileName, position);\n    if (!ast) {\n      return;\n    }\n    const results = getTemplateCompletions(ast, position);\n    if (!results || !results.length) {\n      return;\n    }\n    return {\n      isGlobalCompletion: false,\n      isMemberCompletion: false,\n      isNewIdentifierLocation: false,\n      // Cast CompletionEntry.kind from ng.CompletionKind to ts.ScriptElementKind\n      entries: results as unknown as ts.CompletionEntry[],\n    };\n  }\n\n  getDefinitionAndBoundSpan(fileName: string, position: number): tss.DefinitionInfoAndBoundSpan\n      |undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getDefinitionAndBoundSpan(templateInfo, position);\n    }\n    // Attempt to get Angular-specific definitions in a TypeScript file, like templates defined\n    // in a `templateUrl` property.\n    if (fileName.endsWith('.ts')) {\n      const sf = this.host.getSourceFile(fileName);\n      if (sf) {\n        return getTsDefinitionAndBoundSpan(sf, position, this.host.tsLsHost);\n      }\n    }\n  }\n\n  getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo|undefined {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getTemplateHover(templateInfo, position, analyzedModules);\n    }\n\n    // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a\n    // directive belongs to.\n    const declarations = this.host.getDeclarations(fileName);\n    return getTsHover(position, declarations, analyzedModules);\n  }\n\n  getReferencesAtPosition(fileName: string, position: number): tss.ReferenceEntry[]|undefined {\n    const defAndSpan = this.getDefinitionAndBoundSpan(fileName, position);\n    if (!defAndSpan?.definitions) {\n      return;\n    }\n    const {definitions} = defAndSpan;\n    const tsDef = definitions.find(def => def.fileName.endsWith('.ts'));\n    if (!tsDef) {\n      return;\n    }\n    return this.host.tsLS.getReferencesAtPosition(tsDef.fileName, tsDef.textSpan.start);\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language_service.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/language_service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {getTemplateCompletions} from './completions';\nimport {getDefinitionAndBoundSpan, getTsDefinitionAndBoundSpan} from './definitions';\nimport {getDeclarationDiagnostics, getTemplateDiagnostics, ngDiagnosticToTsDiagnostic} from './diagnostics';\nimport {getTemplateHover, getTsHover} from './hover';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n/**\n * Create an instance of an Angular `LanguageService`.\n *\n * @publicApi\n */\nexport function createLanguageService(host: TypeScriptServiceHost) {\n  return new LanguageServiceImpl(host);\n}\n\nclass LanguageServiceImpl implements ng.LanguageService {\n  constructor(private readonly host: TypeScriptServiceHost) {}\n\n  getSemanticDiagnostics(fileName: string): tss.Diagnostic[] {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ngDiagnostics: ng.Diagnostic[] = [];\n\n    const templates = this.host.getTemplates(fileName);\n    for (const template of templates) {\n      const ast = this.host.getTemplateAst(template);\n      if (ast) {\n        ngDiagnostics.push(...getTemplateDiagnostics(ast));\n      }\n    }\n\n    const declarations = this.host.getDeclarations(fileName);\n    ngDiagnostics.push(...getDeclarationDiagnostics(declarations, analyzedModules, this.host));\n\n    const sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;\n    const tsDiagnostics = ngDiagnostics.map(d => ngDiagnosticToTsDiagnostic(d, sourceFile));\n    return [...tss.sortAndDeduplicateDiagnostics(tsDiagnostics)];\n  }\n\n  getCompletionsAtPosition(\n      fileName: string, position: number,\n      _options?: tss.GetCompletionsAtPositionOptions): tss.CompletionInfo|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ast = this.host.getTemplateAstAtPosition(fileName, position);\n    if (!ast) {\n      return;\n    }\n    const results = getTemplateCompletions(ast, position);\n    if (!results || !results.length) {\n      return;\n    }\n    return {\n      isGlobalCompletion: false,\n      isMemberCompletion: false,\n      isNewIdentifierLocation: false,\n      // Cast CompletionEntry.kind from ng.CompletionKind to ts.ScriptElementKind\n      entries: results as unknown as ts.CompletionEntry[],\n    };\n  }\n\n  getDefinitionAndBoundSpan(fileName: string, position: number): tss.DefinitionInfoAndBoundSpan\n      |undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getDefinitionAndBoundSpan(templateInfo, position);\n    }\n    // Attempt to get Angular-specific definitions in a TypeScript file, like templates defined\n    // in a `templateUrl` property.\n    if (fileName.endsWith('.ts')) {\n      const sf = this.host.getSourceFile(fileName);\n      if (sf) {\n        return getTsDefinitionAndBoundSpan(sf, position, this.host.tsLsHost);\n      }\n    }\n  }\n\n  getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo|undefined {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getTemplateHover(templateInfo, position, analyzedModules);\n    }\n\n    // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a\n    // directive belongs to.\n    const declarations = this.host.getDeclarations(fileName);\n    return getTsHover(position, declarations, analyzedModules);\n  }\n\n  getReferencesAtPosition(fileName: string, position: number): tss.ReferenceEntry[]|undefined {\n    const defAndSpan = this.getDefinitionAndBoundSpan(fileName, position);\n    if (!defAndSpan?.definitions) {\n      return;\n    }\n    const {definitions} = defAndSpan;\n    const tsDef = definitions.find(def => def.fileName.endsWith('.ts'));\n    if (!tsDef) {\n      return;\n    }\n    return this.host.tsLS.getReferencesAtPosition(tsDef.fileName, tsDef.textSpan.start);\n  }\n}\n"]}
@@ -7,6 +7,7 @@
7
7
  */
8
8
  /// <amd-module name="@angular/language-service/src/ts_plugin" />
9
9
  import * as tss from 'typescript/lib/tsserverlibrary';
10
+ import { NgLanguageService } from '../api';
10
11
  /**
11
12
  * This function is called by tsserver to retrieve the external (non-TS) files
12
13
  * that should belong to the specified `project`. For Angular, these files are
@@ -15,4 +16,4 @@ import * as tss from 'typescript/lib/tsserverlibrary';
15
16
  * @param project Project for which external files should be retrieved.
16
17
  */
17
18
  export declare function getExternalFiles(project: tss.server.Project): string[];
18
- export declare function create(info: tss.server.PluginCreateInfo): tss.LanguageService;
19
+ export declare function create(info: tss.server.PluginCreateInfo): NgLanguageService;
package/src/ts_plugin.js CHANGED
@@ -129,6 +129,10 @@
129
129
  // not implemented in VE Language Service
130
130
  return undefined;
131
131
  }
132
+ function getTcb(fileName, position) {
133
+ // Not implemented in VE Language Service
134
+ return undefined;
135
+ }
132
136
  return tslib_1.__assign(tslib_1.__assign({}, tsLS), {
133
137
  // Then override the methods supported by Angular language service
134
138
  getCompletionsAtPosition: getCompletionsAtPosition,
@@ -138,8 +142,9 @@
138
142
  getDefinitionAndBoundSpan: getDefinitionAndBoundSpan,
139
143
  getTypeDefinitionAtPosition: getTypeDefinitionAtPosition,
140
144
  getReferencesAtPosition: getReferencesAtPosition,
141
- findRenameLocations: findRenameLocations });
145
+ findRenameLocations: findRenameLocations,
146
+ getTcb: getTcb });
142
147
  }
143
148
  exports.create = create;
144
149
  });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ts_plugin.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/ts_plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {createLanguageService} from './language_service';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n// Use a WeakMap to keep track of Project to Host mapping so that when Project\n// is deleted Host could be garbage collected.\nconst PROJECT_MAP = new WeakMap<tss.server.Project, TypeScriptServiceHost>();\n\n/**\n * This function is called by tsserver to retrieve the external (non-TS) files\n * that should belong to the specified `project`. For Angular, these files are\n * external templates. This is called once when the project is loaded, then\n * every time when the program is updated.\n * @param project Project for which external files should be retrieved.\n */\nexport function getExternalFiles(project: tss.server.Project): string[] {\n  if (!project.hasRoots()) {\n    // During project initialization where there is no root files yet we should\n    // not do any work.\n    return [];\n  }\n  const ngLsHost = PROJECT_MAP.get(project);\n  if (ngLsHost === undefined) {\n    return [];\n  }\n  ngLsHost.getAnalyzedModules();\n  return ngLsHost.getExternalTemplates().filter(fileName => {\n    // TODO(kyliau): Remove this when the following PR lands on the version of\n    // TypeScript used in this repo.\n    // https://github.com/microsoft/TypeScript/pull/41737\n    return project.fileExists(fileName);\n  });\n}\n\nexport function create(info: tss.server.PluginCreateInfo): tss.LanguageService {\n  const {languageService: tsLS, languageServiceHost: tsLSHost, config, project} = info;\n  // This plugin could operate under two different modes:\n  // 1. TS + Angular\n  //    Plugin augments TS language service to provide additional Angular\n  //    information. This only works with inline templates and is meant to be\n  //    used as a local plugin (configured via tsconfig.json)\n  // 2. Angular only\n  //    Plugin only provides information on Angular templates, no TS info at all.\n  //    This effectively disables native TS features and is meant for internal\n  //    use only.\n  const angularOnly = config ? config.angularOnly === true : false;\n  const ngLSHost = new TypeScriptServiceHost(tsLSHost, tsLS);\n  const ngLS = createLanguageService(ngLSHost);\n  PROJECT_MAP.set(project, ngLSHost);\n\n  function getCompletionsAtPosition(\n      fileName: string, position: number, options: tss.GetCompletionsAtPositionOptions|undefined) {\n    if (!angularOnly) {\n      const results = tsLS.getCompletionsAtPosition(fileName, position, options);\n      if (results && results.entries.length) {\n        // If TS could answer the query, then return results immediately.\n        return results;\n      }\n    }\n    return ngLS.getCompletionsAtPosition(fileName, position, options);\n  }\n\n  function getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo|undefined {\n    if (!angularOnly) {\n      const result = tsLS.getQuickInfoAtPosition(fileName, position);\n      if (result) {\n        // If TS could answer the query, then return results immediately.\n        return result;\n      }\n    }\n    return ngLS.getQuickInfoAtPosition(fileName, position);\n  }\n\n  function getSemanticDiagnostics(fileName: string): tss.Diagnostic[] {\n    const results: tss.Diagnostic[] = [];\n    if (!angularOnly) {\n      results.push(...tsLS.getSemanticDiagnostics(fileName));\n    }\n    // For semantic diagnostics we need to combine both TS + Angular results\n    results.push(...ngLS.getSemanticDiagnostics(fileName));\n    return results;\n  }\n\n  function getDefinitionAtPosition(\n      fileName: string, position: number): ReadonlyArray<tss.DefinitionInfo>|undefined {\n    if (!angularOnly) {\n      const results = tsLS.getDefinitionAtPosition(fileName, position);\n      if (results) {\n        // If TS could answer the query, then return results immediately.\n        return results;\n      }\n    }\n    const result = ngLS.getDefinitionAndBoundSpan(fileName, position);\n    if (!result || !result.definitions || !result.definitions.length) {\n      return;\n    }\n    return result.definitions;\n  }\n\n  function getDefinitionAndBoundSpan(\n      fileName: string, position: number): tss.DefinitionInfoAndBoundSpan|undefined {\n    if (!angularOnly) {\n      const result = tsLS.getDefinitionAndBoundSpan(fileName, position);\n      if (result) {\n        // If TS could answer the query, then return results immediately.\n        return result;\n      }\n    }\n    return ngLS.getDefinitionAndBoundSpan(fileName, position);\n  }\n\n  function getTypeDefinitionAtPosition(fileName: string, position: number) {\n    // Not implemented in VE Language Service\n    return undefined;\n  }\n\n  function getReferencesAtPosition(fileName: string, position: number) {\n    // Not implemented in VE Language Service\n    return undefined;\n  }\n\n  function findRenameLocations(\n      fileName: string, position: number, findInStrings: boolean, findInComments: boolean,\n      providePrefixAndSuffixTextForRename?: boolean): readonly ts.RenameLocation[]|undefined {\n    // not implemented in VE Language Service\n    return undefined;\n  }\n\n  return {\n    // First clone the original TS language service\n    ...tsLS,\n    // Then override the methods supported by Angular language service\n    getCompletionsAtPosition,\n    getQuickInfoAtPosition,\n    getSemanticDiagnostics,\n    getDefinitionAtPosition,\n    getDefinitionAndBoundSpan,\n    getTypeDefinitionAtPosition,\n    getReferencesAtPosition,\n    findRenameLocations,\n  };\n}\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ts_plugin.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/ts_plugin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\nimport {NgLanguageService} from '../api';\n\nimport {createLanguageService} from './language_service';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n// Use a WeakMap to keep track of Project to Host mapping so that when Project\n// is deleted Host could be garbage collected.\nconst PROJECT_MAP = new WeakMap<tss.server.Project, TypeScriptServiceHost>();\n\n/**\n * This function is called by tsserver to retrieve the external (non-TS) files\n * that should belong to the specified `project`. For Angular, these files are\n * external templates. This is called once when the project is loaded, then\n * every time when the program is updated.\n * @param project Project for which external files should be retrieved.\n */\nexport function getExternalFiles(project: tss.server.Project): string[] {\n  if (!project.hasRoots()) {\n    // During project initialization where there is no root files yet we should\n    // not do any work.\n    return [];\n  }\n  const ngLsHost = PROJECT_MAP.get(project);\n  if (ngLsHost === undefined) {\n    return [];\n  }\n  ngLsHost.getAnalyzedModules();\n  return ngLsHost.getExternalTemplates().filter(fileName => {\n    // TODO(kyliau): Remove this when the following PR lands on the version of\n    // TypeScript used in this repo.\n    // https://github.com/microsoft/TypeScript/pull/41737\n    return project.fileExists(fileName);\n  });\n}\n\nexport function create(info: tss.server.PluginCreateInfo): NgLanguageService {\n  const {languageService: tsLS, languageServiceHost: tsLSHost, config, project} = info;\n  // This plugin could operate under two different modes:\n  // 1. TS + Angular\n  //    Plugin augments TS language service to provide additional Angular\n  //    information. This only works with inline templates and is meant to be\n  //    used as a local plugin (configured via tsconfig.json)\n  // 2. Angular only\n  //    Plugin only provides information on Angular templates, no TS info at all.\n  //    This effectively disables native TS features and is meant for internal\n  //    use only.\n  const angularOnly = config ? config.angularOnly === true : false;\n  const ngLSHost = new TypeScriptServiceHost(tsLSHost, tsLS);\n  const ngLS = createLanguageService(ngLSHost);\n  PROJECT_MAP.set(project, ngLSHost);\n\n  function getCompletionsAtPosition(\n      fileName: string, position: number, options: tss.GetCompletionsAtPositionOptions|undefined) {\n    if (!angularOnly) {\n      const results = tsLS.getCompletionsAtPosition(fileName, position, options);\n      if (results && results.entries.length) {\n        // If TS could answer the query, then return results immediately.\n        return results;\n      }\n    }\n    return ngLS.getCompletionsAtPosition(fileName, position, options);\n  }\n\n  function getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo|undefined {\n    if (!angularOnly) {\n      const result = tsLS.getQuickInfoAtPosition(fileName, position);\n      if (result) {\n        // If TS could answer the query, then return results immediately.\n        return result;\n      }\n    }\n    return ngLS.getQuickInfoAtPosition(fileName, position);\n  }\n\n  function getSemanticDiagnostics(fileName: string): tss.Diagnostic[] {\n    const results: tss.Diagnostic[] = [];\n    if (!angularOnly) {\n      results.push(...tsLS.getSemanticDiagnostics(fileName));\n    }\n    // For semantic diagnostics we need to combine both TS + Angular results\n    results.push(...ngLS.getSemanticDiagnostics(fileName));\n    return results;\n  }\n\n  function getDefinitionAtPosition(\n      fileName: string, position: number): ReadonlyArray<tss.DefinitionInfo>|undefined {\n    if (!angularOnly) {\n      const results = tsLS.getDefinitionAtPosition(fileName, position);\n      if (results) {\n        // If TS could answer the query, then return results immediately.\n        return results;\n      }\n    }\n    const result = ngLS.getDefinitionAndBoundSpan(fileName, position);\n    if (!result || !result.definitions || !result.definitions.length) {\n      return;\n    }\n    return result.definitions;\n  }\n\n  function getDefinitionAndBoundSpan(\n      fileName: string, position: number): tss.DefinitionInfoAndBoundSpan|undefined {\n    if (!angularOnly) {\n      const result = tsLS.getDefinitionAndBoundSpan(fileName, position);\n      if (result) {\n        // If TS could answer the query, then return results immediately.\n        return result;\n      }\n    }\n    return ngLS.getDefinitionAndBoundSpan(fileName, position);\n  }\n\n  function getTypeDefinitionAtPosition(fileName: string, position: number) {\n    // Not implemented in VE Language Service\n    return undefined;\n  }\n\n  function getReferencesAtPosition(fileName: string, position: number) {\n    // Not implemented in VE Language Service\n    return undefined;\n  }\n\n  function findRenameLocations(\n      fileName: string, position: number, findInStrings: boolean, findInComments: boolean,\n      providePrefixAndSuffixTextForRename?: boolean): readonly ts.RenameLocation[]|undefined {\n    // not implemented in VE Language Service\n    return undefined;\n  }\n\n  function getTcb(fileName: string, position: number) {\n    // Not implemented in VE Language Service\n    return undefined;\n  }\n\n  return {\n    // First clone the original TS language service\n    ...tsLS,\n    // Then override the methods supported by Angular language service\n    getCompletionsAtPosition,\n    getQuickInfoAtPosition,\n    getSemanticDiagnostics,\n    getDefinitionAtPosition,\n    getDefinitionAndBoundSpan,\n    getTypeDefinitionAtPosition,\n    getReferencesAtPosition,\n    findRenameLocations,\n    getTcb,\n  };\n}\n"]}
@@ -8,11 +8,7 @@
8
8
  /// <amd-module name="@angular/language-service/src/typescript_host" />
9
9
  import { HtmlParser, NgAnalyzedModules, ParseTreeResult, ResourceLoader } from '@angular/compiler';
10
10
  import * as tss from 'typescript/lib/tsserverlibrary';
11
- import { AstResult, Declaration, LanguageService, LanguageServiceHost, TemplateSource } from './types';
12
- /**
13
- * Create a `LanguageServiceHost`
14
- */
15
- export declare function createLanguageServiceFromTypescript(host: tss.LanguageServiceHost, service: tss.LanguageService): LanguageService;
11
+ import { AstResult, Declaration, LanguageServiceHost, TemplateSource } from './types';
16
12
  /**
17
13
  * The language service never needs the normalized versions of the metadata. To avoid parsing
18
14
  * the content and resolving references, return an empty file. This also allows normalizing
@@ -43,6 +39,11 @@ export declare class TypeScriptServiceHost implements LanguageServiceHost {
43
39
  private readonly reflectorHost;
44
40
  private readonly staticSymbolResolver;
45
41
  private readonly staticSymbolCache;
42
+ /**
43
+ * Key of the `fileToComponent` map must be TS internal normalized path (path
44
+ * separator must be `/`), value of the map is the StaticSymbol for the
45
+ * Component class declaration.
46
+ */
46
47
  private readonly fileToComponent;
47
48
  private readonly collectedErrors;
48
49
  private readonly fileVersions;
@@ -63,7 +64,7 @@ export declare class TypeScriptServiceHost implements LanguageServiceHost {
63
64
  /**
64
65
  * Return all known external templates.
65
66
  */
66
- getExternalTemplates(): string[];
67
+ getExternalTemplates(): ts.server.NormalizedPath[];
67
68
  /**
68
69
  * Checks whether the program has changed and returns all analyzed modules.
69
70
  * If program has changed, invalidate all caches and update fileToComponent