@angular/language-service 9.1.0 → 9.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/language-service.umd.js +2195 -989
- package/language-service.d.ts +1 -2
- package/language-service.js +2 -4
- package/package.json +1 -1
- package/src/binding_utils.d.ts +47 -0
- package/src/binding_utils.js +78 -0
- package/src/completions.d.ts +1 -2
- package/src/completions.js +50 -62
- package/src/definitions.d.ts +1 -1
- package/src/definitions.js +5 -6
- package/src/diagnostic_messages.d.ts +1 -1
- package/src/diagnostic_messages.js +5 -4
- package/src/diagnostics.d.ts +1 -2
- package/src/diagnostics.js +1 -1
- package/src/expression_diagnostics.d.ts +4 -13
- package/src/expression_diagnostics.js +14 -5
- package/src/expression_type.d.ts +4 -3
- package/src/expression_type.js +30 -41
- package/src/expressions.js +32 -30
- package/src/hover.d.ts +1 -2
- package/src/hover.js +1 -1
- package/src/html_info.d.ts +0 -1
- package/src/html_info.js +7 -7
- package/src/language_service.d.ts +1 -1
- package/src/language_service.js +2 -2
- package/src/locate_symbol.d.ts +1 -9
- package/src/locate_symbol.js +55 -22
- package/src/reflector_host.js +4 -2
- package/src/symbols.d.ts +9 -6
- package/src/symbols.js +10 -7
- package/src/template.d.ts +0 -30
- package/src/template.js +5 -62
- package/src/ts_plugin.js +6 -3
- package/src/types.d.ts +36 -89
- package/src/types.js +1 -1
- package/src/typescript_host.d.ts +2 -3
- package/src/typescript_host.js +39 -12
- package/src/typescript_symbols.d.ts +0 -2
- package/src/typescript_symbols.js +162 -78
- package/src/utils.d.ts +32 -6
- package/src/utils.js +65 -14
- package/src/common.d.ts +0 -24
- package/src/common.js +0 -20
- package/src/version.d.ts +0 -15
- package/src/version.js +0 -27
package/src/template.js
CHANGED
|
@@ -11,13 +11,12 @@
|
|
|
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/template", ["require", "exports", "tslib", "
|
|
14
|
+
define("@angular/language-service/src/template", ["require", "exports", "tslib", "@angular/language-service/src/global_symbols", "@angular/language-service/src/typescript_symbols"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
19
|
var tslib_1 = require("tslib");
|
|
20
|
-
var ts = require("typescript");
|
|
21
20
|
var global_symbols_1 = require("@angular/language-service/src/global_symbols");
|
|
22
21
|
var typescript_symbols_1 = require("@angular/language-service/src/typescript_symbols");
|
|
23
22
|
/**
|
|
@@ -37,7 +36,9 @@
|
|
|
37
36
|
/**
|
|
38
37
|
* Return the Angular StaticSymbol for the class that contains this template.
|
|
39
38
|
*/
|
|
40
|
-
get: function () {
|
|
39
|
+
get: function () {
|
|
40
|
+
return this.classSymbol;
|
|
41
|
+
},
|
|
41
42
|
enumerable: true,
|
|
42
43
|
configurable: true
|
|
43
44
|
});
|
|
@@ -136,63 +137,5 @@
|
|
|
136
137
|
return ExternalTemplate;
|
|
137
138
|
}(BaseTemplate));
|
|
138
139
|
exports.ExternalTemplate = ExternalTemplate;
|
|
139
|
-
/**
|
|
140
|
-
* Returns a property assignment from the assignment value, or `undefined` if there is no
|
|
141
|
-
* assignment.
|
|
142
|
-
*/
|
|
143
|
-
function getPropertyAssignmentFromValue(value) {
|
|
144
|
-
if (!value.parent || !ts.isPropertyAssignment(value.parent)) {
|
|
145
|
-
return;
|
|
146
|
-
}
|
|
147
|
-
return value.parent;
|
|
148
|
-
}
|
|
149
|
-
exports.getPropertyAssignmentFromValue = getPropertyAssignmentFromValue;
|
|
150
|
-
/**
|
|
151
|
-
* Given a decorator property assignment, return the ClassDeclaration node that corresponds to the
|
|
152
|
-
* directive class the property applies to.
|
|
153
|
-
* If the property assignment is not on a class decorator, no declaration is returned.
|
|
154
|
-
*
|
|
155
|
-
* For example,
|
|
156
|
-
*
|
|
157
|
-
* @Component({
|
|
158
|
-
* template: '<div></div>'
|
|
159
|
-
* ^^^^^^^^^^^^^^^^^^^^^^^---- property assignment
|
|
160
|
-
* })
|
|
161
|
-
* class AppComponent {}
|
|
162
|
-
* ^---- class declaration node
|
|
163
|
-
*
|
|
164
|
-
* @param propAsgn property assignment
|
|
165
|
-
*/
|
|
166
|
-
function getClassDeclFromDecoratorProp(propAsgnNode) {
|
|
167
|
-
if (!propAsgnNode.parent || !ts.isObjectLiteralExpression(propAsgnNode.parent)) {
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
|
-
var objLitExprNode = propAsgnNode.parent;
|
|
171
|
-
if (!objLitExprNode.parent || !ts.isCallExpression(objLitExprNode.parent)) {
|
|
172
|
-
return;
|
|
173
|
-
}
|
|
174
|
-
var callExprNode = objLitExprNode.parent;
|
|
175
|
-
if (!callExprNode.parent || !ts.isDecorator(callExprNode.parent)) {
|
|
176
|
-
return;
|
|
177
|
-
}
|
|
178
|
-
var decorator = callExprNode.parent;
|
|
179
|
-
if (!decorator.parent || !ts.isClassDeclaration(decorator.parent)) {
|
|
180
|
-
return;
|
|
181
|
-
}
|
|
182
|
-
var classDeclNode = decorator.parent;
|
|
183
|
-
return classDeclNode;
|
|
184
|
-
}
|
|
185
|
-
exports.getClassDeclFromDecoratorProp = getClassDeclFromDecoratorProp;
|
|
186
|
-
/**
|
|
187
|
-
* Determines if a property assignment is on a class decorator.
|
|
188
|
-
* See `getClassDeclFromDecoratorProperty`, which gets the class the decorator is applied to, for
|
|
189
|
-
* more details.
|
|
190
|
-
*
|
|
191
|
-
* @param prop property assignment
|
|
192
|
-
*/
|
|
193
|
-
function isClassDecoratorProperty(propAsgn) {
|
|
194
|
-
return !!getClassDeclFromDecoratorProp(propAsgn);
|
|
195
|
-
}
|
|
196
|
-
exports.isClassDecoratorProperty = isClassDecoratorProperty;
|
|
197
140
|
});
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/template.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH,+BAAiC;IAEjC,+EAAyD;IAGzD,uFAAmG;IAGnG;;;;;OAKG;IACH;QAKE,sBACqB,IAA2B,EAC3B,aAAkC,EAClC,WAA4B;YAF5B,SAAI,GAAJ,IAAI,CAAuB;YAC3B,kBAAa,GAAb,aAAa,CAAqB;YAClC,gBAAW,GAAX,WAAW,CAAiB;YAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC9B,CAAC;QASD,sBAAI,8BAAI;YAHR;;eAEG;iBACH,cAAa,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;;;WAAA;QAMvC,sBAAI,iCAAO;YAJX;;;eAGG;iBACH;gBACE,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;oBACtB,IAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;oBAClD,IAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC;oBACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;wBAC9C,wCAAuB,CAAC,IAAI,CAAC,KAAK,CAAC;wBACnC,mDAA8B,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,IAAI,CAAC,aAAa,CAAC;qBAC1F,CAAC,CAAC;iBACJ;gBACD,OAAO,IAAI,CAAC,YAAY,CAAC;YAC3B,CAAC;;;WAAA;QAMD,sBAAI,+BAAK;YAJT;;;eAGG;iBACH;gBAAA,iBAgBC;gBAfC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;oBACpB,IAAM,SAAO,GAAG,IAAI,CAAC,OAAO,CAAC;oBAC7B,IAAM,aAAW,GAAG,SAAO,CAAC,cAAc,EAAE,CAAC;oBAC7C,IAAM,YAAU,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC;oBACtD,IAAI,CAAC,UAAU,GAAG,mCAAc,CAAC,SAAO,EAAE,aAAW,EAAE,YAAU,EAAE;wBACjE,wEAAwE;wBACxE,aAAa;wBACb,qEAAqE;wBACrE,qEAAqE;wBACrE,IAAM,GAAG,GAAG,KAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAI,CAAC,CAAC;wBAC3C,IAAM,KAAK,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;wBACvC,OAAO,kCAAa,CAAC,YAAU,EAAE,SAAO,EAAE,aAAW,EAAE,KAAK,CAAC,CAAC;oBAChE,CAAC,CAAC,CAAC;iBACJ;gBACD,OAAO,IAAI,CAAC,UAAU,CAAC;YACzB,CAAC;;;WAAA;QACH,mBAAC;IAAD,CAAC,AA1DD,IA0DC;IAED;;;OAGG;IACH;QAAoC,0CAAY;QAK9C,wBACI,YAAkC,EAAE,aAAkC,EACtE,WAA4B,EAAE,IAA2B;YAF7D,YAGE,kBAAM,IAAI,EAAE,aAAa,EAAE,WAAW,CAAC,SAcxC;YAbC,IAAM,UAAU,GAAG,YAAY,CAAC,aAAa,EAAE,CAAC;YAChD,IAAI,UAAU,KAAK,aAAa,CAAC,aAAa,EAAE,EAAE;gBAChD,MAAM,IAAI,KAAK,CAAC,2EAA2E,CAAC,CAAC;aAC9F;YACD,KAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;YACpC,2EAA2E;YAC3E,2EAA2E;YAC3E,KAAI,CAAC,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAE,oCAAoC;YACxF,KAAI,CAAC,IAAI,GAAG;gBACV,0EAA0E;gBAC1E,KAAK,EAAE,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC;gBAClC,GAAG,EAAE,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC;aAC/B,CAAC;;QACJ,CAAC;QACH,qBAAC;IAAD,CAAC,AAvBD,CAAoC,YAAY,GAuB/C;IAvBY,wCAAc;IAyB3B;;;;;;OAMG;IACH;QAAsC,4CAAY;QAGhD,0BACoB,MAAc,EAAkB,QAAgB,EAChE,aAAkC,EAAE,WAA4B,EAChE,IAA2B;YAH/B,YAIE,kBAAM,IAAI,EAAE,aAAa,EAAE,WAAW,CAAC,SAKxC;YARmB,YAAM,GAAN,MAAM,CAAQ;YAAkB,cAAQ,GAAR,QAAQ,CAAQ;YAIlE,KAAI,CAAC,IAAI,GAAG;gBACV,KAAK,EAAE,CAAC;gBACR,GAAG,EAAE,MAAM,CAAC,MAAM;aACnB,CAAC;;QACJ,CAAC;QACH,uBAAC;IAAD,CAAC,AAbD,CAAsC,YAAY,GAajD;IAbY,4CAAgB;IAe7B;;;OAGG;IACH,SAAgB,8BAA8B,CAAC,KAAc;QAC3D,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC3D,OAAO;SACR;QACD,OAAO,KAAK,CAAC,MAAM,CAAC;IACtB,CAAC;IALD,wEAKC;IAED;;;;;;;;;;;;;;;OAeG;IACH,SAAgB,6BAA6B,CAAC,YAAmC;QAE/E,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,yBAAyB,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAC9E,OAAO;SACR;QACD,IAAM,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE;YACzE,OAAO;SACR;QACD,IAAM,YAAY,GAAG,cAAc,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAChE,OAAO;SACR;QACD,IAAM,SAAS,GAAG,YAAY,CAAC,MAAM,CAAC;QACtC,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACjE,OAAO;SACR;QACD,IAAM,aAAa,GAAG,SAAS,CAAC,MAAM,CAAC;QACvC,OAAO,aAAa,CAAC;IACvB,CAAC;IAnBD,sEAmBC;IAED;;;;;;OAMG;IACH,SAAgB,wBAAwB,CAAC,QAA+B;QACtE,OAAO,CAAC,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAFD,4DAEC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {createGlobalSymbolTable} from './global_symbols';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\nimport {getClassMembersFromDeclaration, getPipesTable, getSymbolQuery} from './typescript_symbols';\n\n\n/**\n * A base class to represent a template and which component class it is\n * associated with. A template source could answer basic questions about\n * top-level declarations of its class through the members() and query()\n * methods.\n */\nabstract class BaseTemplate implements ng.TemplateSource {\n  private readonly program: ts.Program;\n  private membersTable: ng.SymbolTable|undefined;\n  private queryCache: ng.SymbolQuery|undefined;\n\n  constructor(\n      private readonly host: TypeScriptServiceHost,\n      private readonly classDeclNode: ts.ClassDeclaration,\n      private readonly classSymbol: ng.StaticSymbol) {\n    this.program = host.program;\n  }\n\n  abstract get span(): ng.Span;\n  abstract get fileName(): string;\n  abstract get source(): string;\n\n  /**\n   * Return the Angular StaticSymbol for the class that contains this template.\n   */\n  get type() { return this.classSymbol; }\n\n  /**\n   * Return a Map-like data structure that allows users to retrieve some or all\n   * top-level declarations in the associated component class.\n   */\n  get members() {\n    if (!this.membersTable) {\n      const typeChecker = this.program.getTypeChecker();\n      const sourceFile = this.classDeclNode.getSourceFile();\n      this.membersTable = this.query.mergeSymbolTable([\n        createGlobalSymbolTable(this.query),\n        getClassMembersFromDeclaration(this.program, typeChecker, sourceFile, this.classDeclNode),\n      ]);\n    }\n    return this.membersTable;\n  }\n\n  /**\n   * Return an engine that provides more information about symbols in the\n   * template.\n   */\n  get query() {\n    if (!this.queryCache) {\n      const program = this.program;\n      const typeChecker = program.getTypeChecker();\n      const sourceFile = this.classDeclNode.getSourceFile();\n      this.queryCache = getSymbolQuery(program, typeChecker, sourceFile, () => {\n        // Computing the ast is relatively expensive. Do it only when absolutely\n        // necessary.\n        // TODO: There is circular dependency here between TemplateSource and\n        // TypeScriptHost. Consider refactoring the code to break this cycle.\n        const ast = this.host.getTemplateAst(this);\n        const pipes = (ast && ast.pipes) || [];\n        return getPipesTable(sourceFile, program, typeChecker, pipes);\n      });\n    }\n    return this.queryCache;\n  }\n}\n\n/**\n * An InlineTemplate represents template defined in a TS file through the\n * `template` attribute in the decorator.\n */\nexport class InlineTemplate extends BaseTemplate {\n  public readonly fileName: string;\n  public readonly source: string;\n  public readonly span: ng.Span;\n\n  constructor(\n      templateNode: ts.StringLiteralLike, classDeclNode: ts.ClassDeclaration,\n      classSymbol: ng.StaticSymbol, host: TypeScriptServiceHost) {\n    super(host, classDeclNode, classSymbol);\n    const sourceFile = templateNode.getSourceFile();\n    if (sourceFile !== classDeclNode.getSourceFile()) {\n      throw new Error(`Inline template and component class should belong to the same source file`);\n    }\n    this.fileName = sourceFile.fileName;\n    // node.text returns the TS internal representation of the normalized text,\n    // and all CR characters are stripped. node.getText() returns the raw text.\n    this.source = templateNode.getText().slice(1, -1);  // strip leading and trailing quotes\n    this.span = {\n      // TS string literal includes surrounding quotes in the start/end offsets.\n      start: templateNode.getStart() + 1,\n      end: templateNode.getEnd() - 1,\n    };\n  }\n}\n\n/**\n * An ExternalTemplate represents template defined in an external (most likely\n * HTML, but not necessarily) file through the `templateUrl` attribute in the\n * decorator.\n * Note that there is no ts.Node associated with the template because it's not\n * a TS file.\n */\nexport class ExternalTemplate extends BaseTemplate {\n  public readonly span: ng.Span;\n\n  constructor(\n      public readonly source: string, public readonly fileName: string,\n      classDeclNode: ts.ClassDeclaration, classSymbol: ng.StaticSymbol,\n      host: TypeScriptServiceHost) {\n    super(host, classDeclNode, classSymbol);\n    this.span = {\n      start: 0,\n      end: source.length,\n    };\n  }\n}\n\n/**\n * Returns a property assignment from the assignment value, or `undefined` if there is no\n * assignment.\n */\nexport function getPropertyAssignmentFromValue(value: ts.Node): ts.PropertyAssignment|undefined {\n  if (!value.parent || !ts.isPropertyAssignment(value.parent)) {\n    return;\n  }\n  return value.parent;\n}\n\n/**\n * Given a decorator property assignment, return the ClassDeclaration node that corresponds to the\n * directive class the property applies to.\n * If the property assignment is not on a class decorator, no declaration is returned.\n *\n * For example,\n *\n * @Component({\n *   template: '<div></div>'\n *   ^^^^^^^^^^^^^^^^^^^^^^^---- property assignment\n * })\n * class AppComponent {}\n *           ^---- class declaration node\n *\n * @param propAsgn property assignment\n */\nexport function getClassDeclFromDecoratorProp(propAsgnNode: ts.PropertyAssignment):\n    ts.ClassDeclaration|undefined {\n  if (!propAsgnNode.parent || !ts.isObjectLiteralExpression(propAsgnNode.parent)) {\n    return;\n  }\n  const objLitExprNode = propAsgnNode.parent;\n  if (!objLitExprNode.parent || !ts.isCallExpression(objLitExprNode.parent)) {\n    return;\n  }\n  const callExprNode = objLitExprNode.parent;\n  if (!callExprNode.parent || !ts.isDecorator(callExprNode.parent)) {\n    return;\n  }\n  const decorator = callExprNode.parent;\n  if (!decorator.parent || !ts.isClassDeclaration(decorator.parent)) {\n    return;\n  }\n  const classDeclNode = decorator.parent;\n  return classDeclNode;\n}\n\n/**\n * Determines if a property assignment is on a class decorator.\n * See `getClassDeclFromDecoratorProperty`, which gets the class the decorator is applied to, for\n * more details.\n *\n * @param prop property assignment\n */\nexport function isClassDecoratorProperty(propAsgn: ts.PropertyAssignment): boolean {\n  return !!getClassDeclFromDecoratorProp(propAsgn);\n}\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/template.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {createGlobalSymbolTable} from './global_symbols';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\nimport {getClassMembersFromDeclaration, getPipesTable, getSymbolQuery} from './typescript_symbols';\n\n\n/**\n * A base class to represent a template and which component class it is\n * associated with. A template source could answer basic questions about\n * top-level declarations of its class through the members() and query()\n * methods.\n */\nabstract class BaseTemplate implements ng.TemplateSource {\n  private readonly program: ts.Program;\n  private membersTable: ng.SymbolTable|undefined;\n  private queryCache: ng.SymbolQuery|undefined;\n\n  constructor(\n      private readonly host: TypeScriptServiceHost,\n      private readonly classDeclNode: ts.ClassDeclaration,\n      private readonly classSymbol: ng.StaticSymbol) {\n    this.program = host.program;\n  }\n\n  abstract get span(): ng.Span;\n  abstract get fileName(): string;\n  abstract get source(): string;\n\n  /**\n   * Return the Angular StaticSymbol for the class that contains this template.\n   */\n  get type() {\n    return this.classSymbol;\n  }\n\n  /**\n   * Return a Map-like data structure that allows users to retrieve some or all\n   * top-level declarations in the associated component class.\n   */\n  get members() {\n    if (!this.membersTable) {\n      const typeChecker = this.program.getTypeChecker();\n      const sourceFile = this.classDeclNode.getSourceFile();\n      this.membersTable = this.query.mergeSymbolTable([\n        createGlobalSymbolTable(this.query),\n        getClassMembersFromDeclaration(this.program, typeChecker, sourceFile, this.classDeclNode),\n      ]);\n    }\n    return this.membersTable;\n  }\n\n  /**\n   * Return an engine that provides more information about symbols in the\n   * template.\n   */\n  get query() {\n    if (!this.queryCache) {\n      const program = this.program;\n      const typeChecker = program.getTypeChecker();\n      const sourceFile = this.classDeclNode.getSourceFile();\n      this.queryCache = getSymbolQuery(program, typeChecker, sourceFile, () => {\n        // Computing the ast is relatively expensive. Do it only when absolutely\n        // necessary.\n        // TODO: There is circular dependency here between TemplateSource and\n        // TypeScriptHost. Consider refactoring the code to break this cycle.\n        const ast = this.host.getTemplateAst(this);\n        const pipes = (ast && ast.pipes) || [];\n        return getPipesTable(sourceFile, program, typeChecker, pipes);\n      });\n    }\n    return this.queryCache;\n  }\n}\n\n/**\n * An InlineTemplate represents template defined in a TS file through the\n * `template` attribute in the decorator.\n */\nexport class InlineTemplate extends BaseTemplate {\n  public readonly fileName: string;\n  public readonly source: string;\n  public readonly span: ng.Span;\n\n  constructor(\n      templateNode: ts.StringLiteralLike, classDeclNode: ts.ClassDeclaration,\n      classSymbol: ng.StaticSymbol, host: TypeScriptServiceHost) {\n    super(host, classDeclNode, classSymbol);\n    const sourceFile = templateNode.getSourceFile();\n    if (sourceFile !== classDeclNode.getSourceFile()) {\n      throw new Error(`Inline template and component class should belong to the same source file`);\n    }\n    this.fileName = sourceFile.fileName;\n    // node.text returns the TS internal representation of the normalized text,\n    // and all CR characters are stripped. node.getText() returns the raw text.\n    this.source = templateNode.getText().slice(1, -1);  // strip leading and trailing quotes\n    this.span = {\n      // TS string literal includes surrounding quotes in the start/end offsets.\n      start: templateNode.getStart() + 1,\n      end: templateNode.getEnd() - 1,\n    };\n  }\n}\n\n/**\n * An ExternalTemplate represents template defined in an external (most likely\n * HTML, but not necessarily) file through the `templateUrl` attribute in the\n * decorator.\n * Note that there is no ts.Node associated with the template because it's not\n * a TS file.\n */\nexport class ExternalTemplate extends BaseTemplate {\n  public readonly span: ng.Span;\n\n  constructor(\n      public readonly source: string, public readonly fileName: string,\n      classDeclNode: ts.ClassDeclaration, classSymbol: ng.StaticSymbol,\n      host: TypeScriptServiceHost) {\n    super(host, classDeclNode, classSymbol);\n    this.span = {\n      start: 0,\n      end: source.length,\n    };\n  }\n}\n"]}
|
package/src/ts_plugin.js
CHANGED
|
@@ -91,11 +91,14 @@
|
|
|
91
91
|
{}, tsLS,
|
|
92
92
|
// Then override the methods supported by Angular language service
|
|
93
93
|
{
|
|
94
|
-
getCompletionsAtPosition: getCompletionsAtPosition,
|
|
95
|
-
|
|
94
|
+
getCompletionsAtPosition: getCompletionsAtPosition,
|
|
95
|
+
getQuickInfoAtPosition: getQuickInfoAtPosition,
|
|
96
|
+
getSemanticDiagnostics: getSemanticDiagnostics,
|
|
97
|
+
getDefinitionAtPosition: getDefinitionAtPosition,
|
|
98
|
+
getDefinitionAndBoundSpan: getDefinitionAndBoundSpan,
|
|
96
99
|
});
|
|
97
100
|
return proxy;
|
|
98
101
|
}
|
|
99
102
|
exports.create = create;
|
|
100
103
|
});
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
104
|
+
//# 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 Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {createLanguageService} from './language_service';\nimport {TypeScriptServiceHost} from './typescript_host';\n\nexport function create(info: tss.server.PluginCreateInfo): tss.LanguageService {\n  const {languageService: tsLS, languageServiceHost: tsLSHost, config} = 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\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  const proxy: tss.LanguageService = Object.assign(\n      // First clone the original TS language service\n      {}, tsLS,\n      // Then override the methods supported by Angular language service\n      {\n        getCompletionsAtPosition,\n        getQuickInfoAtPosition,\n        getSemanticDiagnostics,\n        getDefinitionAtPosition,\n        getDefinitionAndBoundSpan,\n      });\n  return proxy;\n}\n"]}
|
package/src/types.d.ts
CHANGED
|
@@ -6,11 +6,11 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
/// <amd-module name="@angular/language-service/src/types" />
|
|
9
|
-
import { CompileDirectiveMetadata, NgAnalyzedModules, StaticSymbol } from '@angular/compiler';
|
|
9
|
+
import { CompileDirectiveMetadata, CompileDirectiveSummary, CompilePipeSummary, CssSelector, NgAnalyzedModules, Node as HtmlAst, ParseError, Parser, StaticSymbol, TemplateAst } from '@angular/compiler';
|
|
10
10
|
import * as ts from 'typescript';
|
|
11
|
-
import {
|
|
12
|
-
|
|
13
|
-
export { BuiltinType,
|
|
11
|
+
import { Span, Symbol, SymbolQuery, SymbolTable } from './symbols';
|
|
12
|
+
export { StaticSymbol } from '@angular/compiler';
|
|
13
|
+
export { BuiltinType, Definition, PipeInfo, Pipes, Signature, Span, Symbol, SymbolDeclaration, SymbolQuery, SymbolTable } from './symbols';
|
|
14
14
|
/**
|
|
15
15
|
* The information `LanguageService` needs from the `LanguageServiceHost` to describe the content of
|
|
16
16
|
* a template and the language context the template is in.
|
|
@@ -45,14 +45,6 @@ export interface TemplateSource {
|
|
|
45
45
|
*/
|
|
46
46
|
readonly fileName: string;
|
|
47
47
|
}
|
|
48
|
-
/**
|
|
49
|
-
* A sequence of template sources.
|
|
50
|
-
*
|
|
51
|
-
* A host type; see `LanguageServiceHost`.
|
|
52
|
-
*
|
|
53
|
-
* @publicApi
|
|
54
|
-
*/
|
|
55
|
-
export declare type TemplateSources = TemplateSource[] | undefined;
|
|
56
48
|
/**
|
|
57
49
|
* Error information found getting declaration information
|
|
58
50
|
*
|
|
@@ -103,14 +95,6 @@ export interface Declaration {
|
|
|
103
95
|
*/
|
|
104
96
|
readonly errors: DeclarationError[];
|
|
105
97
|
}
|
|
106
|
-
/**
|
|
107
|
-
* A sequence of declarations.
|
|
108
|
-
*
|
|
109
|
-
* A host type; see `LanguageServiceHost`.
|
|
110
|
-
*
|
|
111
|
-
* @publicApi
|
|
112
|
-
*/
|
|
113
|
-
export declare type Declarations = Declaration[];
|
|
114
98
|
/**
|
|
115
99
|
* The host for a `LanguageService`. This provides all the `LanguageService` requires to respond
|
|
116
100
|
* to the `LanguageService` requests.
|
|
@@ -147,7 +131,7 @@ export interface LanguageServiceHost {
|
|
|
147
131
|
/**
|
|
148
132
|
* Returns the Angular declarations in the given file.
|
|
149
133
|
*/
|
|
150
|
-
getDeclarations(fileName: string):
|
|
134
|
+
getDeclarations(fileName: string): Declaration[];
|
|
151
135
|
/**
|
|
152
136
|
* Return a summary of all Angular modules in the project.
|
|
153
137
|
*/
|
|
@@ -161,40 +145,6 @@ export interface LanguageServiceHost {
|
|
|
161
145
|
*/
|
|
162
146
|
getTemplateAstAtPosition(fileName: string, position: number): AstResult | undefined;
|
|
163
147
|
}
|
|
164
|
-
/**
|
|
165
|
-
* An item of the completion result to be displayed by an editor.
|
|
166
|
-
*
|
|
167
|
-
* A `LanguageService` interface.
|
|
168
|
-
*
|
|
169
|
-
* @publicApi
|
|
170
|
-
*/
|
|
171
|
-
export interface Completion {
|
|
172
|
-
/**
|
|
173
|
-
* The kind of completion.
|
|
174
|
-
*/
|
|
175
|
-
kind: DeclarationKind;
|
|
176
|
-
/**
|
|
177
|
-
* The name of the completion to be displayed
|
|
178
|
-
*/
|
|
179
|
-
name: string;
|
|
180
|
-
/**
|
|
181
|
-
* The key to use to sort the completions for display.
|
|
182
|
-
*/
|
|
183
|
-
sort: string;
|
|
184
|
-
}
|
|
185
|
-
/**
|
|
186
|
-
* A sequence of completions.
|
|
187
|
-
*
|
|
188
|
-
* @deprecated
|
|
189
|
-
*/
|
|
190
|
-
export declare type Completions = Completion[];
|
|
191
|
-
/**
|
|
192
|
-
* A file and span.
|
|
193
|
-
*/
|
|
194
|
-
export interface Location {
|
|
195
|
-
fileName: string;
|
|
196
|
-
span: Span;
|
|
197
|
-
}
|
|
198
148
|
/**
|
|
199
149
|
* The type of Angular directive. Used for QuickInfo in template.
|
|
200
150
|
*/
|
|
@@ -264,40 +214,6 @@ export interface Diagnostic {
|
|
|
264
214
|
*/
|
|
265
215
|
message: string | DiagnosticMessageChain;
|
|
266
216
|
}
|
|
267
|
-
/**
|
|
268
|
-
* A sequence of diagnostic message.
|
|
269
|
-
*
|
|
270
|
-
* @deprecated
|
|
271
|
-
*/
|
|
272
|
-
export declare type Diagnostics = Diagnostic[];
|
|
273
|
-
/**
|
|
274
|
-
* A section of hover text. If the text is code then language should be provided.
|
|
275
|
-
* Otherwise the text is assumed to be Markdown text that will be sanitized.
|
|
276
|
-
*/
|
|
277
|
-
export interface HoverTextSection {
|
|
278
|
-
/**
|
|
279
|
-
* Source code or markdown text describing the symbol a the hover location.
|
|
280
|
-
*/
|
|
281
|
-
readonly text: string;
|
|
282
|
-
/**
|
|
283
|
-
* The language of the source if `text` is a source code fragment.
|
|
284
|
-
*/
|
|
285
|
-
readonly language?: string;
|
|
286
|
-
}
|
|
287
|
-
/**
|
|
288
|
-
* Hover information for a symbol at the hover location.
|
|
289
|
-
*/
|
|
290
|
-
export interface Hover {
|
|
291
|
-
/**
|
|
292
|
-
* The hover text to display for the symbol at the hover location. If the text includes
|
|
293
|
-
* source code, the section will specify which language it should be interpreted as.
|
|
294
|
-
*/
|
|
295
|
-
readonly text: HoverTextSection[];
|
|
296
|
-
/**
|
|
297
|
-
* The span of source the hover covers.
|
|
298
|
-
*/
|
|
299
|
-
readonly span: Span;
|
|
300
|
-
}
|
|
301
217
|
/**
|
|
302
218
|
* An instance of an Angular language service created by `createLanguageService()`.
|
|
303
219
|
*
|
|
@@ -308,3 +224,34 @@ export interface Hover {
|
|
|
308
224
|
* @publicApi
|
|
309
225
|
*/
|
|
310
226
|
export declare type LanguageService = Pick<ts.LanguageService, 'getCompletionsAtPosition' | 'getDefinitionAndBoundSpan' | 'getQuickInfoAtPosition' | 'getSemanticDiagnostics'>;
|
|
227
|
+
/** Information about an Angular template AST. */
|
|
228
|
+
export interface AstResult {
|
|
229
|
+
htmlAst: HtmlAst[];
|
|
230
|
+
templateAst: TemplateAst[];
|
|
231
|
+
directive: CompileDirectiveMetadata;
|
|
232
|
+
directives: CompileDirectiveSummary[];
|
|
233
|
+
pipes: CompilePipeSummary[];
|
|
234
|
+
parseErrors?: ParseError[];
|
|
235
|
+
expressionParser: Parser;
|
|
236
|
+
template: TemplateSource;
|
|
237
|
+
}
|
|
238
|
+
/** Information about a directive's selectors. */
|
|
239
|
+
export declare type SelectorInfo = {
|
|
240
|
+
selectors: CssSelector[];
|
|
241
|
+
map: Map<CssSelector, CompileDirectiveSummary>;
|
|
242
|
+
};
|
|
243
|
+
export interface SymbolInfo {
|
|
244
|
+
symbol: Symbol;
|
|
245
|
+
span: ts.TextSpan;
|
|
246
|
+
staticSymbol?: StaticSymbol;
|
|
247
|
+
}
|
|
248
|
+
/** TODO: this should probably be merged with AstResult */
|
|
249
|
+
export interface DiagnosticTemplateInfo {
|
|
250
|
+
fileName?: string;
|
|
251
|
+
offset: number;
|
|
252
|
+
query: SymbolQuery;
|
|
253
|
+
members: SymbolTable;
|
|
254
|
+
htmlAst: HtmlAst[];
|
|
255
|
+
templateAst: TemplateAst[];
|
|
256
|
+
source: string;
|
|
257
|
+
}
|
package/src/types.js
CHANGED
|
@@ -50,4 +50,4 @@
|
|
|
50
50
|
CompletionKind["VARIABLE"] = "variable";
|
|
51
51
|
})(CompletionKind = exports.CompletionKind || (exports.CompletionKind = {}));
|
|
52
52
|
});
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/types.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAEH,8CAA4F;IAa1F,uBAbmD,uBAAY,CAanD;IAVd,iEAA0J;IAGxJ,sBAHM,qBAAW,CAGN;IA+Nb;;OAEG;IACH,IAAY,aAIX;IAJD,WAAY,aAAa;QACvB,wCAAuB,CAAA;QACvB,wCAAuB,CAAA;QACvB,gCAAe,CAAA;IACjB,CAAC,EAJW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAIxB;IAED;;OAEG;IACH,IAAY,cAeX;IAfD,WAAY,cAAc;QACxB,qDAAmC,CAAA;QACnC,yCAAuB,CAAA;QACvB,yCAAuB,CAAA;QACvB,qCAAmB,CAAA;QACnB,mCAAiB,CAAA;QACjB,mDAAiC,CAAA;QACjC,+CAA6B,CAAA;QAC7B,6BAAW,CAAA;QACX,mCAAiB,CAAA;QACjB,+BAAa,CAAA;QACb,uCAAqB,CAAA;QACrB,yCAAuB,CAAA;QACvB,+BAAa,CAAA;QACb,uCAAqB,CAAA;IACvB,CAAC,EAfW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAezB","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 {CompileDirectiveMetadata, NgAnalyzedModules, StaticSymbol} from '@angular/compiler';\nimport * as ts from 'typescript';\nimport {AstResult} from './common';\nimport {BuiltinType, DeclarationKind, Definition, PipeInfo, Pipes, Signature, Span, Symbol, SymbolDeclaration, SymbolQuery, SymbolTable} from './symbols';\n\nexport {\n  BuiltinType,\n  DeclarationKind,\n  Definition,\n  PipeInfo,\n  Pipes,\n  Signature,\n  Span,\n  StaticSymbol,\n  Symbol,\n  SymbolDeclaration,\n  SymbolQuery,\n  SymbolTable\n};\n\n\n/**\n * The information `LanguageService` needs from the `LanguageServiceHost` to describe the content of\n * a template and the language context the template is in.\n *\n * A host interface; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface TemplateSource {\n  /**\n   * The source of the template.\n   */\n  readonly source: string;\n\n  /**\n   * The span of the template within the source file.\n   */\n  readonly span: Span;\n\n  /**\n   * A static symbol for the template's component.\n   */\n  readonly type: StaticSymbol;\n\n  /**\n   * The `SymbolTable` for the members of the component.\n   */\n  readonly members: SymbolTable;\n\n  /**\n   * A `SymbolQuery` for the context of the template.\n   */\n  readonly query: SymbolQuery;\n\n  /**\n   * Name of the file that contains the template. Could be `.html` or `.ts`.\n   */\n  readonly fileName: string;\n}\n\n/**\n * A sequence of template sources.\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport type TemplateSources = TemplateSource[] | undefined;\n\n/**\n * Error information found getting declaration information\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface DeclarationError {\n  /**\n   * The span of the error in the declaration's module.\n   */\n  readonly span: Span;\n\n  /**\n   * The message to display describing the error or a chain\n   * of messages.\n   */\n  readonly message: string|DiagnosticMessageChain;\n}\n\n/**\n * Information about the component declarations.\n *\n * A file might contain a declaration without a template because the file contains only\n * templateUrl references. However, the component declaration might contain errors that\n * need to be reported such as the template string is missing or the component is not\n * declared in a module. These error should be reported on the declaration, not the\n * template.\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface Declaration {\n  /**\n   * The static symbol of the compponent being declared.\n   */\n  readonly type: StaticSymbol;\n\n  /**\n   * The span of the declaration annotation reference (e.g. the 'Component' or 'Directive'\n   * reference).\n   */\n  readonly declarationSpan: Span;\n\n  /**\n   * Reference to the compiler directive metadata for the declaration.\n   */\n  readonly metadata: CompileDirectiveMetadata;\n\n  /**\n   * Error reported trying to get the metadata.\n   */\n  readonly errors: DeclarationError[];\n}\n\n/**\n * A sequence of declarations.\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport type Declarations = Declaration[];\n\n/**\n * The host for a `LanguageService`. This provides all the `LanguageService` requires to respond\n * to the `LanguageService` requests.\n *\n * This interface describes the requirements of the `LanguageService` on its host.\n *\n * The host interface is host language agnostic.\n *\n * Adding optional member to this interface or any interface that is described as a\n * `LanguageServiceHost` interface is not considered a breaking change as defined by SemVer.\n * Removing a method or changing a member from required to optional will also not be considered a\n * breaking change.\n *\n * If a member is deprecated it will be changed to optional in a minor release before it is\n * removed in a major release.\n *\n * Adding a required member or changing a method's parameters, is considered a breaking change and\n * will only be done when breaking changes are allowed. When possible, a new optional member will\n * be added and the old member will be deprecated. The new member will then be made required in\n * and the old member will be removed only when breaking changes are allowed.\n *\n * While an interface is marked as experimental breaking-changes will be allowed between minor\n * releases. After an interface is marked as stable breaking-changes will only be allowed between\n * major releases. No breaking changes are allowed between patch releases.\n *\n * @publicApi\n */\nexport interface LanguageServiceHost {\n  /**\n   * Return the template source information for all templates in `fileName` or for `fileName` if\n   * it is a template file.\n   */\n  getTemplates(fileName: string): TemplateSource[];\n\n  /**\n   * Returns the Angular declarations in the given file.\n   */\n  getDeclarations(fileName: string): Declarations;\n\n  /**\n   * Return a summary of all Angular modules in the project.\n   */\n  getAnalyzedModules(): NgAnalyzedModules;\n\n  /**\n   * Return the AST for both HTML and template for the contextFile.\n   */\n  getTemplateAst(template: TemplateSource): AstResult|undefined;\n\n  /**\n   * Return the template AST for the node that corresponds to the position.\n   */\n  getTemplateAstAtPosition(fileName: string, position: number): AstResult|undefined;\n}\n\n/**\n * An item of the completion result to be displayed by an editor.\n *\n * A `LanguageService` interface.\n *\n * @publicApi\n */\nexport interface Completion {\n  /**\n   * The kind of completion.\n   */\n  kind: DeclarationKind;\n\n  /**\n   * The name of the completion to be displayed\n   */\n  name: string;\n\n  /**\n   * The key to use to sort the completions for display.\n   */\n  sort: string;\n}\n\n/**\n * A sequence of completions.\n *\n * @deprecated\n */\nexport type Completions = Completion[];\n\n/**\n * A file and span.\n */\nexport interface Location {\n  fileName: string;\n  span: Span;\n}\n\n/**\n * The type of Angular directive. Used for QuickInfo in template.\n */\nexport enum DirectiveKind {\n  COMPONENT = 'component',\n  DIRECTIVE = 'directive',\n  EVENT = 'event',\n}\n\n/**\n * ScriptElementKind for completion.\n */\nexport enum CompletionKind {\n  ANGULAR_ELEMENT = 'angular element',\n  ATTRIBUTE = 'attribute',\n  COMPONENT = 'component',\n  ELEMENT = 'element',\n  ENTITY = 'entity',\n  HTML_ATTRIBUTE = 'html attribute',\n  HTML_ELEMENT = 'html element',\n  KEY = 'key',\n  METHOD = 'method',\n  PIPE = 'pipe',\n  PROPERTY = 'property',\n  REFERENCE = 'reference',\n  TYPE = 'type',\n  VARIABLE = 'variable',\n}\n\nexport type CompletionEntry = Omit<ts.CompletionEntry, 'kind'>& {\n  kind: CompletionKind,\n};\n\n/**\n * A template diagnostics message chain. This is similar to the TypeScript\n * DiagnosticMessageChain. The messages are intended to be formatted as separate\n * sentence fragments and indented.\n *\n * For compatibility previous implementation, the values are expected to override\n * toString() to return a formatted message.\n *\n * @publicApi\n */\nexport interface DiagnosticMessageChain {\n  /**\n   * The text of the diagnostic message to display.\n   */\n  message: string;\n\n  /**\n   * The next message in the chain.\n   */\n  next?: DiagnosticMessageChain[];\n}\n\n/**\n * An template diagnostic message to display.\n *\n * @publicApi\n */\nexport interface Diagnostic {\n  /**\n   * The kind of diagnostic message\n   */\n  kind: ts.DiagnosticCategory;\n\n  /**\n   * The source span that should be highlighted.\n   */\n  span: Span;\n\n  /**\n   * The text of the diagnostic message to display or a chain of messages.\n   */\n  message: string|DiagnosticMessageChain;\n}\n\n/**\n * A sequence of diagnostic message.\n *\n * @deprecated\n */\nexport type Diagnostics = Diagnostic[];\n\n/**\n * A section of hover text. If the text is code then language should be provided.\n * Otherwise the text is assumed to be Markdown text that will be sanitized.\n */\nexport interface HoverTextSection {\n  /**\n   * Source code or markdown text describing the symbol a the hover location.\n   */\n  readonly text: string;\n\n  /**\n   * The language of the source if `text` is a source code fragment.\n   */\n  readonly language?: string;\n}\n\n/**\n * Hover information for a symbol at the hover location.\n */\nexport interface Hover {\n  /**\n   * The hover text to display for the symbol at the hover location. If the text includes\n   * source code, the section will specify which language it should be interpreted as.\n   */\n  readonly text: HoverTextSection[];\n\n  /**\n   * The span of source the hover covers.\n   */\n  readonly span: Span;\n}\n\n/**\n * An instance of an Angular language service created by `createLanguageService()`.\n *\n * The Angular language service implements a subset of methods defined in\n * The Angular language service implements a subset of methods defined by\n * the TypeScript language service.\n *\n * @publicApi\n */\nexport type LanguageService = Pick<\n    ts.LanguageService, 'getCompletionsAtPosition'|'getDefinitionAndBoundSpan'|\n    'getQuickInfoAtPosition'|'getSemanticDiagnostics'>;\n"]}
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/types.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAOH,8CAA+C;IAAvC,kCAAA,YAAY,CAAA;IACpB,iEAAyI;IAAjI,gCAAA,WAAW,CAAA;IAyJnB;;OAEG;IACH,IAAY,aAIX;IAJD,WAAY,aAAa;QACvB,wCAAuB,CAAA;QACvB,wCAAuB,CAAA;QACvB,gCAAe,CAAA;IACjB,CAAC,EAJW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAIxB;IAED;;OAEG;IACH,IAAY,cAeX;IAfD,WAAY,cAAc;QACxB,qDAAmC,CAAA;QACnC,yCAAuB,CAAA;QACvB,yCAAuB,CAAA;QACvB,qCAAmB,CAAA;QACnB,mCAAiB,CAAA;QACjB,mDAAiC,CAAA;QACjC,+CAA6B,CAAA;QAC7B,6BAAW,CAAA;QACX,mCAAiB,CAAA;QACjB,+BAAa,CAAA;QACb,uCAAqB,CAAA;QACrB,yCAAuB,CAAA;QACvB,+BAAa,CAAA;QACb,uCAAqB,CAAA;IACvB,CAAC,EAfW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAezB","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 {CompileDirectiveMetadata, CompileDirectiveSummary, CompilePipeSummary, CssSelector, NgAnalyzedModules, Node as HtmlAst, ParseError, Parser, StaticSymbol, TemplateAst} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {Span, Symbol, SymbolQuery, SymbolTable} from './symbols';\n\nexport {StaticSymbol} from '@angular/compiler';\nexport {BuiltinType, Definition, PipeInfo, Pipes, Signature, Span, Symbol, SymbolDeclaration, SymbolQuery, SymbolTable} from './symbols';\n\n/**\n * The information `LanguageService` needs from the `LanguageServiceHost` to describe the content of\n * a template and the language context the template is in.\n *\n * A host interface; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface TemplateSource {\n  /**\n   * The source of the template.\n   */\n  readonly source: string;\n\n  /**\n   * The span of the template within the source file.\n   */\n  readonly span: Span;\n\n  /**\n   * A static symbol for the template's component.\n   */\n  readonly type: StaticSymbol;\n\n  /**\n   * The `SymbolTable` for the members of the component.\n   */\n  readonly members: SymbolTable;\n\n  /**\n   * A `SymbolQuery` for the context of the template.\n   */\n  readonly query: SymbolQuery;\n\n  /**\n   * Name of the file that contains the template. Could be `.html` or `.ts`.\n   */\n  readonly fileName: string;\n}\n\n/**\n * Error information found getting declaration information\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface DeclarationError {\n  /**\n   * The span of the error in the declaration's module.\n   */\n  readonly span: Span;\n\n  /**\n   * The message to display describing the error or a chain\n   * of messages.\n   */\n  readonly message: string|DiagnosticMessageChain;\n}\n\n/**\n * Information about the component declarations.\n *\n * A file might contain a declaration without a template because the file contains only\n * templateUrl references. However, the component declaration might contain errors that\n * need to be reported such as the template string is missing or the component is not\n * declared in a module. These error should be reported on the declaration, not the\n * template.\n *\n * A host type; see `LanguageServiceHost`.\n *\n * @publicApi\n */\nexport interface Declaration {\n  /**\n   * The static symbol of the compponent being declared.\n   */\n  readonly type: StaticSymbol;\n\n  /**\n   * The span of the declaration annotation reference (e.g. the 'Component' or 'Directive'\n   * reference).\n   */\n  readonly declarationSpan: Span;\n\n  /**\n   * Reference to the compiler directive metadata for the declaration.\n   */\n  readonly metadata: CompileDirectiveMetadata;\n\n  /**\n   * Error reported trying to get the metadata.\n   */\n  readonly errors: DeclarationError[];\n}\n\n/**\n * The host for a `LanguageService`. This provides all the `LanguageService` requires to respond\n * to the `LanguageService` requests.\n *\n * This interface describes the requirements of the `LanguageService` on its host.\n *\n * The host interface is host language agnostic.\n *\n * Adding optional member to this interface or any interface that is described as a\n * `LanguageServiceHost` interface is not considered a breaking change as defined by SemVer.\n * Removing a method or changing a member from required to optional will also not be considered a\n * breaking change.\n *\n * If a member is deprecated it will be changed to optional in a minor release before it is\n * removed in a major release.\n *\n * Adding a required member or changing a method's parameters, is considered a breaking change and\n * will only be done when breaking changes are allowed. When possible, a new optional member will\n * be added and the old member will be deprecated. The new member will then be made required in\n * and the old member will be removed only when breaking changes are allowed.\n *\n * While an interface is marked as experimental breaking-changes will be allowed between minor\n * releases. After an interface is marked as stable breaking-changes will only be allowed between\n * major releases. No breaking changes are allowed between patch releases.\n *\n * @publicApi\n */\nexport interface LanguageServiceHost {\n  /**\n   * Return the template source information for all templates in `fileName` or for `fileName` if\n   * it is a template file.\n   */\n  getTemplates(fileName: string): TemplateSource[];\n\n  /**\n   * Returns the Angular declarations in the given file.\n   */\n  getDeclarations(fileName: string): Declaration[];\n\n  /**\n   * Return a summary of all Angular modules in the project.\n   */\n  getAnalyzedModules(): NgAnalyzedModules;\n\n  /**\n   * Return the AST for both HTML and template for the contextFile.\n   */\n  getTemplateAst(template: TemplateSource): AstResult|undefined;\n\n  /**\n   * Return the template AST for the node that corresponds to the position.\n   */\n  getTemplateAstAtPosition(fileName: string, position: number): AstResult|undefined;\n}\n\n/**\n * The type of Angular directive. Used for QuickInfo in template.\n */\nexport enum DirectiveKind {\n  COMPONENT = 'component',\n  DIRECTIVE = 'directive',\n  EVENT = 'event',\n}\n\n/**\n * ScriptElementKind for completion.\n */\nexport enum CompletionKind {\n  ANGULAR_ELEMENT = 'angular element',\n  ATTRIBUTE = 'attribute',\n  COMPONENT = 'component',\n  ELEMENT = 'element',\n  ENTITY = 'entity',\n  HTML_ATTRIBUTE = 'html attribute',\n  HTML_ELEMENT = 'html element',\n  KEY = 'key',\n  METHOD = 'method',\n  PIPE = 'pipe',\n  PROPERTY = 'property',\n  REFERENCE = 'reference',\n  TYPE = 'type',\n  VARIABLE = 'variable',\n}\n\nexport type CompletionEntry = Omit<ts.CompletionEntry, 'kind'>&{\n  kind: CompletionKind,\n};\n\n/**\n * A template diagnostics message chain. This is similar to the TypeScript\n * DiagnosticMessageChain. The messages are intended to be formatted as separate\n * sentence fragments and indented.\n *\n * For compatibility previous implementation, the values are expected to override\n * toString() to return a formatted message.\n *\n * @publicApi\n */\nexport interface DiagnosticMessageChain {\n  /**\n   * The text of the diagnostic message to display.\n   */\n  message: string;\n\n  /**\n   * The next message in the chain.\n   */\n  next?: DiagnosticMessageChain[];\n}\n\n/**\n * An template diagnostic message to display.\n *\n * @publicApi\n */\nexport interface Diagnostic {\n  /**\n   * The kind of diagnostic message\n   */\n  kind: ts.DiagnosticCategory;\n\n  /**\n   * The source span that should be highlighted.\n   */\n  span: Span;\n\n  /**\n   * The text of the diagnostic message to display or a chain of messages.\n   */\n  message: string|DiagnosticMessageChain;\n}\n\n/**\n * An instance of an Angular language service created by `createLanguageService()`.\n *\n * The Angular language service implements a subset of methods defined in\n * The Angular language service implements a subset of methods defined by\n * the TypeScript language service.\n *\n * @publicApi\n */\nexport type LanguageService = Pick<\n    ts.LanguageService,\n    'getCompletionsAtPosition'|'getDefinitionAndBoundSpan'|'getQuickInfoAtPosition'|\n    'getSemanticDiagnostics'>;\n\n/** Information about an Angular template AST. */\nexport interface AstResult {\n  htmlAst: HtmlAst[];\n  templateAst: TemplateAst[];\n  directive: CompileDirectiveMetadata;\n  directives: CompileDirectiveSummary[];\n  pipes: CompilePipeSummary[];\n  parseErrors?: ParseError[];\n  expressionParser: Parser;\n  template: TemplateSource;\n}\n\n/** Information about a directive's selectors. */\nexport type SelectorInfo = {\n  selectors: CssSelector[],\n  map: Map<CssSelector, CompileDirectiveSummary>\n};\n\nexport interface SymbolInfo {\n  symbol: Symbol;\n  span: ts.TextSpan;\n  staticSymbol?: StaticSymbol;\n}\n\n/** TODO: this should probably be merged with AstResult */\nexport interface DiagnosticTemplateInfo {\n  fileName?: string;\n  offset: number;\n  query: SymbolQuery;\n  members: SymbolTable;\n  htmlAst: HtmlAst[];\n  templateAst: TemplateAst[];\n  source: string;\n}\n"]}
|
package/src/typescript_host.d.ts
CHANGED
|
@@ -8,8 +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 } from './
|
|
12
|
-
import { Declaration, LanguageService, LanguageServiceHost, TemplateSource } from './types';
|
|
11
|
+
import { AstResult, Declaration, LanguageService, LanguageServiceHost, TemplateSource } from './types';
|
|
13
12
|
/**
|
|
14
13
|
* Create a `LanguageServiceHost`
|
|
15
14
|
*/
|
|
@@ -27,7 +26,7 @@ export declare class DummyHtmlParser extends HtmlParser {
|
|
|
27
26
|
* Avoid loading resources in the language servcie by using a dummy loader.
|
|
28
27
|
*/
|
|
29
28
|
export declare class DummyResourceLoader extends ResourceLoader {
|
|
30
|
-
get(
|
|
29
|
+
get(_url: string): Promise<string>;
|
|
31
30
|
}
|
|
32
31
|
/**
|
|
33
32
|
* An implementation of a `LanguageServiceHost` for a TypeScript project.
|