@angular/language-service 11.2.9 → 11.2.13

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.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v11.2.9
2
+ * @license Angular v11.2.13
3
3
  * Copyright Google LLC All Rights Reserved.
4
4
  * License: MIT
5
5
  */
@@ -8307,6 +8307,34 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
8307
8307
  rule.selector.startsWith('@page') || rule.selector.startsWith('@document')) {
8308
8308
  content = this._scopeSelectors(rule.content, scopeSelector, hostSelector);
8309
8309
  }
8310
+ else if (rule.selector.startsWith('@font-face')) {
8311
+ content = this._stripScopingSelectors(rule.content, scopeSelector, hostSelector);
8312
+ }
8313
+ return new CssRule(selector, content);
8314
+ });
8315
+ }
8316
+ /**
8317
+ * Handle a css text that is within a rule that should not contain scope selectors by simply
8318
+ * removing them! An example of such a rule is `@font-face`.
8319
+ *
8320
+ * `@font-face` rules cannot contain nested selectors. Nor can they be nested under a selector.
8321
+ * Normally this would be a syntax error by the author of the styles. But in some rare cases, such
8322
+ * as importing styles from a library, and applying `:host ::ng-deep` to the imported styles, we
8323
+ * can end up with broken css if the imported styles happen to contain @font-face rules.
8324
+ *
8325
+ * For example:
8326
+ *
8327
+ * ```
8328
+ * :host ::ng-deep {
8329
+ * import 'some/lib/containing/font-face';
8330
+ * }
8331
+ * ```
8332
+ */
8333
+ _stripScopingSelectors(cssText, scopeSelector, hostSelector) {
8334
+ return processRules(cssText, rule => {
8335
+ const selector = rule.selector.replace(_shadowDeepSelectors, ' ')
8336
+ .replace(_polyfillHostNoCombinatorRe, ' ');
8337
+ const content = this._scopeSelectors(rule.content, scopeSelector, hostSelector);
8310
8338
  return new CssRule(selector, content);
8311
8339
  });
8312
8340
  }
@@ -19180,7 +19208,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
19180
19208
  * Use of this source code is governed by an MIT-style license that can be
19181
19209
  * found in the LICENSE file at https://angular.io/license
19182
19210
  */
19183
- const VERSION$1 = new Version('11.2.9');
19211
+ const VERSION$1 = new Version('11.2.13');
19184
19212
 
19185
19213
  /**
19186
19214
  * @license
@@ -19728,6 +19756,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
19728
19756
  * found in the LICENSE file at https://angular.io/license
19729
19757
  */
19730
19758
  const ERROR_COMPONENT_TYPE = 'ngComponentType';
19759
+ const MISSING_NG_MODULE_METADATA_ERROR_DATA = 'ngMissingNgModuleMetadataErrorData';
19731
19760
  // Design notes:
19732
19761
  // - don't lazily create metadata:
19733
19762
  // For some metadata, we need to do async work sometimes,
@@ -20195,7 +20224,16 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
20195
20224
  const importedModuleSummary = this.getNgModuleSummary(importedModuleType, alreadyCollecting);
20196
20225
  alreadyCollecting.delete(importedModuleType);
20197
20226
  if (!importedModuleSummary) {
20198
- this._reportError(syntaxError(`Unexpected ${this._getTypeDescriptor(importedType)} '${stringifyType(importedType)}' imported by the module '${stringifyType(moduleType)}'. Please add a @NgModule annotation.`), moduleType);
20227
+ const err = syntaxError(`Unexpected ${this._getTypeDescriptor(importedType)} '${stringifyType(importedType)}' imported by the module '${stringifyType(moduleType)}'. Please add a @NgModule annotation.`);
20228
+ // If possible, record additional context for this error to enable more useful
20229
+ // diagnostics on the compiler side.
20230
+ if (importedType instanceof StaticSymbol) {
20231
+ err[MISSING_NG_MODULE_METADATA_ERROR_DATA] = {
20232
+ fileName: importedType.filePath,
20233
+ className: importedType.name,
20234
+ };
20235
+ }
20236
+ this._reportError(err, moduleType);
20199
20237
  return;
20200
20238
  }
20201
20239
  importedModules.push(importedModuleSummary);
@@ -35232,7 +35270,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
35232
35270
  /**
35233
35271
  * @publicApi
35234
35272
  */
35235
- const VERSION$2 = new Version$1('11.2.9');
35273
+ const VERSION$2 = new Version$1('11.2.13');
35236
35274
 
35237
35275
  /**
35238
35276
  * @license
@@ -36418,9 +36456,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
36418
36456
  /**
36419
36457
  * Marks a view and all of its ancestors dirty.
36420
36458
  *
36421
- * It also triggers change detection by calling `scheduleTick` internally, which coalesces
36422
- * multiple `markForCheck` calls to into one change detection run.
36423
- *
36424
36459
  * This can be used to ensure an {@link ChangeDetectionStrategy#OnPush OnPush} component is
36425
36460
  * checked when it needs to be re-rendered but the two normal triggers haven't marked it
36426
36461
  * dirty (i.e. inputs haven't changed and events haven't fired in the view).
@@ -38500,58 +38535,37 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
38500
38535
  super.next(value);
38501
38536
  }
38502
38537
  subscribe(observerOrNext, error, complete) {
38503
- let schedulerFn;
38504
- let errorFn = (err) => null;
38505
- let completeFn = () => null;
38538
+ var _a, _b, _c;
38539
+ let nextFn = observerOrNext;
38540
+ let errorFn = error || (() => null);
38541
+ let completeFn = complete;
38506
38542
  if (observerOrNext && typeof observerOrNext === 'object') {
38507
- schedulerFn = this.__isAsync ? (value) => {
38508
- setTimeout(() => observerOrNext.next(value));
38509
- } : (value) => {
38510
- observerOrNext.next(value);
38511
- };
38512
- if (observerOrNext.error) {
38513
- errorFn = this.__isAsync ? (err) => {
38514
- setTimeout(() => observerOrNext.error(err));
38515
- } : (err) => {
38516
- observerOrNext.error(err);
38517
- };
38518
- }
38519
- if (observerOrNext.complete) {
38520
- completeFn = this.__isAsync ? () => {
38521
- setTimeout(() => observerOrNext.complete());
38522
- } : () => {
38523
- observerOrNext.complete();
38524
- };
38525
- }
38543
+ const observer = observerOrNext;
38544
+ nextFn = (_a = observer.next) === null || _a === void 0 ? void 0 : _a.bind(observer);
38545
+ errorFn = (_b = observer.error) === null || _b === void 0 ? void 0 : _b.bind(observer);
38546
+ completeFn = (_c = observer.complete) === null || _c === void 0 ? void 0 : _c.bind(observer);
38526
38547
  }
38527
- else {
38528
- schedulerFn = this.__isAsync ? (value) => {
38529
- setTimeout(() => observerOrNext(value));
38530
- } : (value) => {
38531
- observerOrNext(value);
38532
- };
38533
- if (error) {
38534
- errorFn = this.__isAsync ? (err) => {
38535
- setTimeout(() => error(err));
38536
- } : (err) => {
38537
- error(err);
38538
- };
38548
+ if (this.__isAsync) {
38549
+ errorFn = _wrapInTimeout(errorFn);
38550
+ if (nextFn) {
38551
+ nextFn = _wrapInTimeout(nextFn);
38539
38552
  }
38540
- if (complete) {
38541
- completeFn = this.__isAsync ? () => {
38542
- setTimeout(() => complete());
38543
- } : () => {
38544
- complete();
38545
- };
38553
+ if (completeFn) {
38554
+ completeFn = _wrapInTimeout(completeFn);
38546
38555
  }
38547
38556
  }
38548
- const sink = super.subscribe(schedulerFn, errorFn, completeFn);
38557
+ const sink = super.subscribe({ next: nextFn, error: errorFn, complete: completeFn });
38549
38558
  if (observerOrNext instanceof Subscription) {
38550
38559
  observerOrNext.add(sink);
38551
38560
  }
38552
38561
  return sink;
38553
38562
  }
38554
38563
  }
38564
+ function _wrapInTimeout(fn) {
38565
+ return (value) => {
38566
+ setTimeout(fn, undefined, value);
38567
+ };
38568
+ }
38555
38569
  /**
38556
38570
  * @publicApi
38557
38571
  */
package/ivy/adapters.d.ts CHANGED
@@ -26,6 +26,7 @@ export declare class LanguageServiceAdapter implements NgCompilerAdapter {
26
26
  */
27
27
  private readonly lastReadResourceVersion;
28
28
  constructor(project: ts.server.Project);
29
+ resourceNameToFileName(url: string, fromFile: string, fallbackResolve?: (url: string, fromFile: string) => string | null): string | null;
29
30
  isShim(sf: ts.SourceFile): boolean;
30
31
  fileExists(fileName: string): boolean;
31
32
  readFile(fileName: string): string | undefined;
package/ivy/adapters.js CHANGED
@@ -22,6 +22,7 @@
22
22
  var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
23
23
  var p = require("path");
24
24
  var utils_1 = require("@angular/language-service/ivy/utils");
25
+ var PRE_COMPILED_STYLE_EXTENSIONS = ['.scss', '.sass', '.less', '.styl'];
25
26
  var LanguageServiceAdapter = /** @class */ (function () {
26
27
  function LanguageServiceAdapter(project) {
27
28
  this.project = project;
@@ -38,6 +39,33 @@
38
39
  this.lastReadResourceVersion = new Map();
39
40
  this.rootDirs = typescript_1.getRootDirs(this, project.getCompilationSettings());
40
41
  }
42
+ LanguageServiceAdapter.prototype.resourceNameToFileName = function (url, fromFile, fallbackResolve) {
43
+ var e_1, _a;
44
+ var _b;
45
+ // If we are trying to resolve a `.css` file, see if we can find a pre-compiled file with the
46
+ // same name instead. That way, we can provide go-to-definition for the pre-compiled files which
47
+ // would generally be the desired behavior.
48
+ if (url.endsWith('.css')) {
49
+ var styleUrl = p.resolve(fromFile, '..', url);
50
+ try {
51
+ for (var PRE_COMPILED_STYLE_EXTENSIONS_1 = tslib_1.__values(PRE_COMPILED_STYLE_EXTENSIONS), PRE_COMPILED_STYLE_EXTENSIONS_1_1 = PRE_COMPILED_STYLE_EXTENSIONS_1.next(); !PRE_COMPILED_STYLE_EXTENSIONS_1_1.done; PRE_COMPILED_STYLE_EXTENSIONS_1_1 = PRE_COMPILED_STYLE_EXTENSIONS_1.next()) {
52
+ var ext = PRE_COMPILED_STYLE_EXTENSIONS_1_1.value;
53
+ var precompiledFileUrl = styleUrl.replace(/\.css$/, ext);
54
+ if (this.fileExists(precompiledFileUrl)) {
55
+ return precompiledFileUrl;
56
+ }
57
+ }
58
+ }
59
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
60
+ finally {
61
+ try {
62
+ if (PRE_COMPILED_STYLE_EXTENSIONS_1_1 && !PRE_COMPILED_STYLE_EXTENSIONS_1_1.done && (_a = PRE_COMPILED_STYLE_EXTENSIONS_1.return)) _a.call(PRE_COMPILED_STYLE_EXTENSIONS_1);
63
+ }
64
+ finally { if (e_1) throw e_1.error; }
65
+ }
66
+ }
67
+ return (_b = fallbackResolve === null || fallbackResolve === void 0 ? void 0 : fallbackResolve(url, fromFile)) !== null && _b !== void 0 ? _b : null;
68
+ };
41
69
  LanguageServiceAdapter.prototype.isShim = function (sf) {
42
70
  return shims_1.isShim(sf);
43
71
  };
@@ -87,7 +115,7 @@
87
115
  return snapshot.getText(0, snapshot.getLength());
88
116
  };
89
117
  LanguageServiceAdapter.prototype.getModifiedResourceFiles = function () {
90
- var e_1, _a;
118
+ var e_2, _a;
91
119
  var modifiedFiles = new Set();
92
120
  try {
93
121
  for (var _b = tslib_1.__values(this.lastReadResourceVersion), _c = _b.next(); !_c.done; _c = _b.next()) {
@@ -97,12 +125,12 @@
97
125
  }
98
126
  }
99
127
  }
100
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
128
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
101
129
  finally {
102
130
  try {
103
131
  if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
104
132
  }
105
- finally { if (e_1) throw e_1.error; }
133
+ finally { if (e_2) throw e_2.error; }
106
134
  }
107
135
  return modifiedFiles.size > 0 ? modifiedFiles : undefined;
108
136
  };
@@ -171,4 +199,4 @@
171
199
  }());
172
200
  exports.LSParseConfigHost = LSParseConfigHost;
173
201
  });
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/adapters.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\n/** @fileoverview provides adapters for communicating with the ng compiler */\n\nimport {ConfigurationHost} from '@angular/compiler-cli';\nimport {NgCompilerAdapter} from '@angular/compiler-cli/src/ngtsc/core/api';\nimport {AbsoluteFsPath, FileStats, PathSegment, PathString} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {isShim} from '@angular/compiler-cli/src/ngtsc/shims';\nimport {getRootDirs} from '@angular/compiler-cli/src/ngtsc/util/src/typescript';\nimport * as p from 'path';\nimport * as ts from 'typescript/lib/tsserverlibrary';\n\nimport {isTypeScriptFile} from './utils';\n\nexport class LanguageServiceAdapter implements NgCompilerAdapter {\n  readonly entryPoint = null;\n  readonly constructionDiagnostics: ts.Diagnostic[] = [];\n  readonly ignoreForEmit: Set<ts.SourceFile> = new Set();\n  readonly factoryTracker = null;      // no .ngfactory shims\n  readonly unifiedModulesHost = null;  // only used in Bazel\n  readonly rootDirs: AbsoluteFsPath[];\n\n  /**\n   * Map of resource filenames to the version of the file last read via `readResource`.\n   *\n   * Used to implement `getModifiedResourceFiles`.\n   */\n  private readonly lastReadResourceVersion = new Map<string, string>();\n\n  constructor(private readonly project: ts.server.Project) {\n    this.rootDirs = getRootDirs(this, project.getCompilationSettings());\n  }\n\n  isShim(sf: ts.SourceFile): boolean {\n    return isShim(sf);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.project.fileExists(fileName);\n  }\n\n  readFile(fileName: string): string|undefined {\n    return this.project.readFile(fileName);\n  }\n\n  getCurrentDirectory(): string {\n    return this.project.getCurrentDirectory();\n  }\n\n  getCanonicalFileName(fileName: string): string {\n    return this.project.projectService.toCanonicalFileName(fileName);\n  }\n\n  /**\n   * Return the real path of a symlink. This method is required in order to\n   * resolve symlinks in node_modules.\n   */\n  realpath(path: string): string {\n    return this.project.realpath?.(path) ?? path;\n  }\n\n  /**\n   * readResource() is an Angular-specific method for reading files that are not\n   * managed by the TS compiler host, namely templates and stylesheets.\n   * It is a method on ExtendedTsCompilerHost, see\n   * packages/compiler-cli/src/ngtsc/core/api/src/interfaces.ts\n   */\n  readResource(fileName: string): string {\n    if (isTypeScriptFile(fileName)) {\n      throw new Error(`readResource() should not be called on TS file: ${fileName}`);\n    }\n    // Calling getScriptSnapshot() will actually create a ScriptInfo if it does\n    // not exist! The same applies for getScriptVersion().\n    // getScriptInfo() will not create one if it does not exist.\n    // In this case, we *want* a script info to be created so that we could\n    // keep track of its version.\n    const snapshot = this.project.getScriptSnapshot(fileName);\n    if (!snapshot) {\n      // This would fail if the file does not exist, or readFile() fails for\n      // whatever reasons.\n      throw new Error(`Failed to get script snapshot while trying to read ${fileName}`);\n    }\n    const version = this.project.getScriptVersion(fileName);\n    this.lastReadResourceVersion.set(fileName, version);\n    return snapshot.getText(0, snapshot.getLength());\n  }\n\n  getModifiedResourceFiles(): Set<string>|undefined {\n    const modifiedFiles = new Set<string>();\n    for (const [fileName, oldVersion] of this.lastReadResourceVersion) {\n      if (this.project.getScriptVersion(fileName) !== oldVersion) {\n        modifiedFiles.add(fileName);\n      }\n    }\n    return modifiedFiles.size > 0 ? modifiedFiles : undefined;\n  }\n}\n\n/**\n * Used to read configuration files.\n *\n * A language service parse configuration host is independent of the adapter\n * because signatures of calls like `FileSystem#readFile` are a bit stricter\n * than those on the adapter.\n */\nexport class LSParseConfigHost implements ConfigurationHost {\n  constructor(private readonly serverHost: ts.server.ServerHost) {}\n  exists(path: AbsoluteFsPath): boolean {\n    return this.serverHost.fileExists(path) || this.serverHost.directoryExists(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    const content = this.serverHost.readFile(path);\n    if (content === undefined) {\n      throw new Error(`LanguageServiceFS#readFile called on unavailable file ${path}`);\n    }\n    return content;\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return {\n      isFile: () => {\n        return this.serverHost.fileExists(path);\n      },\n      isDirectory: () => {\n        return this.serverHost.directoryExists(path);\n      },\n      isSymbolicLink: () => {\n        throw new Error(`LanguageServiceFS#lstat#isSymbolicLink not implemented`);\n      },\n    };\n  }\n  pwd(): AbsoluteFsPath {\n    return this.serverHost.getCurrentDirectory() as AbsoluteFsPath;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return p.resolve(...paths) as AbsoluteFsPath;\n  }\n  dirname<T extends PathString>(file: T): T {\n    return p.dirname(file) as T;\n  }\n  join<T extends PathString>(basePath: T, ...paths: string[]): T {\n    return p.join(basePath, ...paths) as T;\n  }\n}\n"]}
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/adapters.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;;IAOH,+DAA6D;IAC7D,kFAAgF;IAChF,wBAA0B;IAG1B,6DAAyC;IAEzC,IAAM,6BAA6B,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAE3E;QAeE,gCAA6B,OAA0B;YAA1B,YAAO,GAAP,OAAO,CAAmB;YAd9C,eAAU,GAAG,IAAI,CAAC;YAClB,4BAAuB,GAAoB,EAAE,CAAC;YAC9C,kBAAa,GAAuB,IAAI,GAAG,EAAE,CAAC;YAC9C,mBAAc,GAAG,IAAI,CAAC,CAAM,sBAAsB;YAClD,uBAAkB,GAAG,IAAI,CAAC,CAAE,qBAAqB;YAG1D;;;;eAIG;YACc,4BAAuB,GAAG,IAAI,GAAG,EAAkB,CAAC;YAGnE,IAAI,CAAC,QAAQ,GAAG,wBAAW,CAAC,IAAI,EAAE,OAAO,CAAC,sBAAsB,EAAE,CAAC,CAAC;QACtE,CAAC;QAED,uDAAsB,GAAtB,UACI,GAAW,EAAE,QAAgB,EAC7B,eAAkE;;;YACpE,6FAA6F;YAC7F,gGAAgG;YAChG,2CAA2C;YAC3C,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;gBACxB,IAAM,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;;oBAChD,KAAkB,IAAA,kCAAA,iBAAA,6BAA6B,CAAA,4EAAA,uHAAE;wBAA5C,IAAM,GAAG,0CAAA;wBACZ,IAAM,kBAAkB,GAAG,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;wBAC3D,IAAI,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE;4BACvC,OAAO,kBAAkB,CAAC;yBAC3B;qBACF;;;;;;;;;aACF;YACD,aAAO,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,GAAG,EAAE,QAAQ,oCAAK,IAAI,CAAC;QAClD,CAAC;QAED,uCAAM,GAAN,UAAO,EAAiB;YACtB,OAAO,cAAM,CAAC,EAAE,CAAC,CAAC;QACpB,CAAC;QAED,2CAAU,GAAV,UAAW,QAAgB;YACzB,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC;QAED,yCAAQ,GAAR,UAAS,QAAgB;YACvB,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACzC,CAAC;QAED,oDAAmB,GAAnB;YACE,OAAO,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,CAAC;QAC5C,CAAC;QAED,qDAAoB,GAApB,UAAqB,QAAgB;YACnC,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACnE,CAAC;QAED;;;WAGG;QACH,yCAAQ,GAAR,UAAS,IAAY;;YACnB,mBAAO,MAAA,IAAI,CAAC,OAAO,EAAC,QAAQ,mDAAG,IAAI,oCAAK,IAAI,CAAC;QAC/C,CAAC;QAED;;;;;WAKG;QACH,6CAAY,GAAZ,UAAa,QAAgB;YAC3B,IAAI,wBAAgB,CAAC,QAAQ,CAAC,EAAE;gBAC9B,MAAM,IAAI,KAAK,CAAC,qDAAmD,QAAU,CAAC,CAAC;aAChF;YACD,2EAA2E;YAC3E,sDAAsD;YACtD,4DAA4D;YAC5D,uEAAuE;YACvE,6BAA6B;YAC7B,IAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAC1D,IAAI,CAAC,QAAQ,EAAE;gBACb,sEAAsE;gBACtE,oBAAoB;gBACpB,MAAM,IAAI,KAAK,CAAC,wDAAsD,QAAU,CAAC,CAAC;aACnF;YACD,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YACxD,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACpD,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAE,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC;QACnD,CAAC;QAED,yDAAwB,GAAxB;;YACE,IAAM,aAAa,GAAG,IAAI,GAAG,EAAU,CAAC;;gBACxC,KAAqC,IAAA,KAAA,iBAAA,IAAI,CAAC,uBAAuB,CAAA,gBAAA,4BAAE;oBAAxD,IAAA,KAAA,2BAAsB,EAArB,QAAQ,QAAA,EAAE,UAAU,QAAA;oBAC9B,IAAI,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,UAAU,EAAE;wBAC1D,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;qBAC7B;iBACF;;;;;;;;;YACD,OAAO,aAAa,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QAC5D,CAAC;QACH,6BAAC;IAAD,CAAC,AApGD,IAoGC;IApGY,wDAAsB;IAsGnC;;;;;;OAMG;IACH;QACE,2BAA6B,UAAgC;YAAhC,eAAU,GAAV,UAAU,CAAsB;QAAG,CAAC;QACjE,kCAAM,GAAN,UAAO,IAAoB;YACzB,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACnF,CAAC;QACD,oCAAQ,GAAR,UAAS,IAAoB;YAC3B,IAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,OAAO,KAAK,SAAS,EAAE;gBACzB,MAAM,IAAI,KAAK,CAAC,2DAAyD,IAAM,CAAC,CAAC;aAClF;YACD,OAAO,OAAO,CAAC;QACjB,CAAC;QACD,iCAAK,GAAL,UAAM,IAAoB;YAA1B,iBAYC;YAXC,OAAO;gBACL,MAAM,EAAE;oBACN,OAAO,KAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC1C,CAAC;gBACD,WAAW,EAAE;oBACX,OAAO,KAAI,CAAC,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;gBAC/C,CAAC;gBACD,cAAc,EAAE;oBACd,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;gBAC5E,CAAC;aACF,CAAC;QACJ,CAAC;QACD,+BAAG,GAAH;YACE,OAAO,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAoB,CAAC;QACjE,CAAC;QACD,mCAAO,GAAP,UAAQ,IAAgC;YACtC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;QACD,mCAAO,GAAP;YAAQ,eAAkB;iBAAlB,UAAkB,EAAlB,qBAAkB,EAAlB,IAAkB;gBAAlB,0BAAkB;;YACxB,OAAO,CAAC,CAAC,OAAO,OAAT,CAAC,mBAAY,KAAK,EAAmB,CAAC;QAC/C,CAAC;QACD,mCAAO,GAAP,UAA8B,IAAO;YACnC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAM,CAAC;QAC9B,CAAC;QACD,gCAAI,GAAJ,UAA2B,QAAW;YAAE,eAAkB;iBAAlB,UAAkB,EAAlB,qBAAkB,EAAlB,IAAkB;gBAAlB,8BAAkB;;YACxD,OAAO,CAAC,CAAC,IAAI,OAAN,CAAC,oBAAM,QAAQ,GAAK,KAAK,EAAM,CAAC;QACzC,CAAC;QACH,wBAAC;IAAD,CAAC,AAxCD,IAwCC;IAxCY,8CAAiB","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\n/** @fileoverview provides adapters for communicating with the ng compiler */\n\nimport {ConfigurationHost} from '@angular/compiler-cli';\nimport {NgCompilerAdapter} from '@angular/compiler-cli/src/ngtsc/core/api';\nimport {AbsoluteFsPath, FileStats, PathSegment, PathString} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {isShim} from '@angular/compiler-cli/src/ngtsc/shims';\nimport {getRootDirs} from '@angular/compiler-cli/src/ngtsc/util/src/typescript';\nimport * as p from 'path';\nimport * as ts from 'typescript/lib/tsserverlibrary';\n\nimport {isTypeScriptFile} from './utils';\n\nconst PRE_COMPILED_STYLE_EXTENSIONS = ['.scss', '.sass', '.less', '.styl'];\n\nexport class LanguageServiceAdapter implements NgCompilerAdapter {\n  readonly entryPoint = null;\n  readonly constructionDiagnostics: ts.Diagnostic[] = [];\n  readonly ignoreForEmit: Set<ts.SourceFile> = new Set();\n  readonly factoryTracker = null;      // no .ngfactory shims\n  readonly unifiedModulesHost = null;  // only used in Bazel\n  readonly rootDirs: AbsoluteFsPath[];\n\n  /**\n   * Map of resource filenames to the version of the file last read via `readResource`.\n   *\n   * Used to implement `getModifiedResourceFiles`.\n   */\n  private readonly lastReadResourceVersion = new Map<string, string>();\n\n  constructor(private readonly project: ts.server.Project) {\n    this.rootDirs = getRootDirs(this, project.getCompilationSettings());\n  }\n\n  resourceNameToFileName(\n      url: string, fromFile: string,\n      fallbackResolve?: (url: string, fromFile: string) => string | null): string|null {\n    // If we are trying to resolve a `.css` file, see if we can find a pre-compiled file with the\n    // same name instead. That way, we can provide go-to-definition for the pre-compiled files which\n    // would generally be the desired behavior.\n    if (url.endsWith('.css')) {\n      const styleUrl = p.resolve(fromFile, '..', url);\n      for (const ext of PRE_COMPILED_STYLE_EXTENSIONS) {\n        const precompiledFileUrl = styleUrl.replace(/\\.css$/, ext);\n        if (this.fileExists(precompiledFileUrl)) {\n          return precompiledFileUrl;\n        }\n      }\n    }\n    return fallbackResolve?.(url, fromFile) ?? null;\n  }\n\n  isShim(sf: ts.SourceFile): boolean {\n    return isShim(sf);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.project.fileExists(fileName);\n  }\n\n  readFile(fileName: string): string|undefined {\n    return this.project.readFile(fileName);\n  }\n\n  getCurrentDirectory(): string {\n    return this.project.getCurrentDirectory();\n  }\n\n  getCanonicalFileName(fileName: string): string {\n    return this.project.projectService.toCanonicalFileName(fileName);\n  }\n\n  /**\n   * Return the real path of a symlink. This method is required in order to\n   * resolve symlinks in node_modules.\n   */\n  realpath(path: string): string {\n    return this.project.realpath?.(path) ?? path;\n  }\n\n  /**\n   * readResource() is an Angular-specific method for reading files that are not\n   * managed by the TS compiler host, namely templates and stylesheets.\n   * It is a method on ExtendedTsCompilerHost, see\n   * packages/compiler-cli/src/ngtsc/core/api/src/interfaces.ts\n   */\n  readResource(fileName: string): string {\n    if (isTypeScriptFile(fileName)) {\n      throw new Error(`readResource() should not be called on TS file: ${fileName}`);\n    }\n    // Calling getScriptSnapshot() will actually create a ScriptInfo if it does\n    // not exist! The same applies for getScriptVersion().\n    // getScriptInfo() will not create one if it does not exist.\n    // In this case, we *want* a script info to be created so that we could\n    // keep track of its version.\n    const snapshot = this.project.getScriptSnapshot(fileName);\n    if (!snapshot) {\n      // This would fail if the file does not exist, or readFile() fails for\n      // whatever reasons.\n      throw new Error(`Failed to get script snapshot while trying to read ${fileName}`);\n    }\n    const version = this.project.getScriptVersion(fileName);\n    this.lastReadResourceVersion.set(fileName, version);\n    return snapshot.getText(0, snapshot.getLength());\n  }\n\n  getModifiedResourceFiles(): Set<string>|undefined {\n    const modifiedFiles = new Set<string>();\n    for (const [fileName, oldVersion] of this.lastReadResourceVersion) {\n      if (this.project.getScriptVersion(fileName) !== oldVersion) {\n        modifiedFiles.add(fileName);\n      }\n    }\n    return modifiedFiles.size > 0 ? modifiedFiles : undefined;\n  }\n}\n\n/**\n * Used to read configuration files.\n *\n * A language service parse configuration host is independent of the adapter\n * because signatures of calls like `FileSystem#readFile` are a bit stricter\n * than those on the adapter.\n */\nexport class LSParseConfigHost implements ConfigurationHost {\n  constructor(private readonly serverHost: ts.server.ServerHost) {}\n  exists(path: AbsoluteFsPath): boolean {\n    return this.serverHost.fileExists(path) || this.serverHost.directoryExists(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    const content = this.serverHost.readFile(path);\n    if (content === undefined) {\n      throw new Error(`LanguageServiceFS#readFile called on unavailable file ${path}`);\n    }\n    return content;\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return {\n      isFile: () => {\n        return this.serverHost.fileExists(path);\n      },\n      isDirectory: () => {\n        return this.serverHost.directoryExists(path);\n      },\n      isSymbolicLink: () => {\n        throw new Error(`LanguageServiceFS#lstat#isSymbolicLink not implemented`);\n      },\n    };\n  }\n  pwd(): AbsoluteFsPath {\n    return this.serverHost.getCurrentDirectory() as AbsoluteFsPath;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return p.resolve(...paths) as AbsoluteFsPath;\n  }\n  dirname<T extends PathString>(file: T): T {\n    return p.dirname(file) as T;\n  }\n  join<T extends PathString>(basePath: T, ...paths: string[]): T {\n    return p.join(basePath, ...paths) as T;\n  }\n}\n"]}
@@ -100,4 +100,9 @@ export declare class CompletionBuilder<N extends TmplAstNode | AST> {
100
100
  private getElementAttributeCompletionSymbol;
101
101
  private isPipeCompletion;
102
102
  private getPipeCompletions;
103
+ /**
104
+ * From the AST node of the cursor position, include completion of string literals, number
105
+ * literals, `true`, `false`, `null`, and `undefined`.
106
+ */
107
+ private isValidNodeContextCompletion;
103
108
  }