@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.
- package/bundles/ivy.js +478 -292
- package/bundles/language-service.js +62 -48
- package/ivy/adapters.d.ts +1 -0
- package/ivy/adapters.js +32 -4
- package/ivy/completions.d.ts +5 -0
- package/ivy/completions.js +60 -18
- package/ivy/references.js +2 -4
- package/ivy/utils.js +2 -2
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v11.2.
|
|
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.
|
|
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
|
-
|
|
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.
|
|
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
|
-
|
|
38504
|
-
let
|
|
38505
|
-
let
|
|
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
|
-
|
|
38508
|
-
|
|
38509
|
-
|
|
38510
|
-
|
|
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
|
-
|
|
38528
|
-
|
|
38529
|
-
|
|
38530
|
-
|
|
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 (
|
|
38541
|
-
completeFn =
|
|
38542
|
-
setTimeout(() => complete());
|
|
38543
|
-
} : () => {
|
|
38544
|
-
complete();
|
|
38545
|
-
};
|
|
38553
|
+
if (completeFn) {
|
|
38554
|
+
completeFn = _wrapInTimeout(completeFn);
|
|
38546
38555
|
}
|
|
38547
38556
|
}
|
|
38548
|
-
const sink = super.subscribe(
|
|
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
|
|
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 (
|
|
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 (
|
|
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":"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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\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"]}
|
package/ivy/completions.d.ts
CHANGED
|
@@ -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
|
}
|