1 | /**
|
2 | * @license
|
3 | * Copyright Google LLC All Rights Reserved.
|
4 | *
|
5 | * Use of this source code is governed by an MIT-style license that can be
|
6 | * found in the LICENSE file at https://angular.io/license
|
7 | */
|
8 | (function (factory) {
|
9 | if (typeof module === "object" && typeof module.exports === "object") {
|
10 | var v = factory(require, exports);
|
11 | if (v !== undefined) module.exports = v;
|
12 | }
|
13 | else if (typeof define === "function" && define.amd) {
|
14 | define("@angular/language-service/ivy/adapters", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/shims", "@angular/compiler-cli/src/ngtsc/util/src/typescript", "path", "@angular/language-service/ivy/utils"], factory);
|
15 | }
|
16 | })(function (require, exports) {
|
17 | ;
|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
19 | exports.LSParseConfigHost = exports.LanguageServiceAdapter = void 0;
|
20 | var tslib_1 = require("tslib");
|
21 | var shims_1 = require("@angular/compiler-cli/src/ngtsc/shims");
|
22 | var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
|
23 | var p = require("path");
|
24 | var utils_1 = require("@angular/language-service/ivy/utils");
|
25 | var LanguageServiceAdapter = /** @class */ (function () {
|
26 | function LanguageServiceAdapter(project) {
|
27 | this.project = project;
|
28 | this.entryPoint = null;
|
29 | this.constructionDiagnostics = [];
|
30 | this.ignoreForEmit = new Set();
|
31 | this.factoryTracker = null; // no .ngfactory shims
|
32 | this.unifiedModulesHost = null; // only used in Bazel
|
33 | /**
|
34 | * Map of resource filenames to the version of the file last read via `readResource`.
|
35 | *
|
36 | * Used to implement `getModifiedResourceFiles`.
|
37 | */
|
38 | this.lastReadResourceVersion = new Map();
|
39 | this.rootDirs = typescript_1.getRootDirs(this, project.getCompilationSettings());
|
40 | }
|
41 | LanguageServiceAdapter.prototype.isShim = function (sf) {
|
42 | return shims_1.isShim(sf);
|
43 | };
|
44 | LanguageServiceAdapter.prototype.fileExists = function (fileName) {
|
45 | return this.project.fileExists(fileName);
|
46 | };
|
47 | LanguageServiceAdapter.prototype.readFile = function (fileName) {
|
48 | return this.project.readFile(fileName);
|
49 | };
|
50 | LanguageServiceAdapter.prototype.getCurrentDirectory = function () {
|
51 | return this.project.getCurrentDirectory();
|
52 | };
|
53 | LanguageServiceAdapter.prototype.getCanonicalFileName = function (fileName) {
|
54 | return this.project.projectService.toCanonicalFileName(fileName);
|
55 | };
|
56 | /**
|
57 | * Return the real path of a symlink. This method is required in order to
|
58 | * resolve symlinks in node_modules.
|
59 | */
|
60 | LanguageServiceAdapter.prototype.realpath = function (path) {
|
61 | var _a, _b, _c;
|
62 | return (_c = (_b = (_a = this.project).realpath) === null || _b === void 0 ? void 0 : _b.call(_a, path)) !== null && _c !== void 0 ? _c : path;
|
63 | };
|
64 | /**
|
65 | * readResource() is an Angular-specific method for reading files that are not
|
66 | * managed by the TS compiler host, namely templates and stylesheets.
|
67 | * It is a method on ExtendedTsCompilerHost, see
|
68 | * packages/compiler-cli/src/ngtsc/core/api/src/interfaces.ts
|
69 | */
|
70 | LanguageServiceAdapter.prototype.readResource = function (fileName) {
|
71 | if (utils_1.isTypeScriptFile(fileName)) {
|
72 | throw new Error("readResource() should not be called on TS file: " + fileName);
|
73 | }
|
74 | // Calling getScriptSnapshot() will actually create a ScriptInfo if it does
|
75 | // not exist! The same applies for getScriptVersion().
|
76 | // getScriptInfo() will not create one if it does not exist.
|
77 | // In this case, we *want* a script info to be created so that we could
|
78 | // keep track of its version.
|
79 | var snapshot = this.project.getScriptSnapshot(fileName);
|
80 | if (!snapshot) {
|
81 | // This would fail if the file does not exist, or readFile() fails for
|
82 | // whatever reasons.
|
83 | throw new Error("Failed to get script snapshot while trying to read " + fileName);
|
84 | }
|
85 | var version = this.project.getScriptVersion(fileName);
|
86 | this.lastReadResourceVersion.set(fileName, version);
|
87 | return snapshot.getText(0, snapshot.getLength());
|
88 | };
|
89 | LanguageServiceAdapter.prototype.getModifiedResourceFiles = function () {
|
90 | var e_1, _a;
|
91 | var modifiedFiles = new Set();
|
92 | try {
|
93 | for (var _b = tslib_1.__values(this.lastReadResourceVersion), _c = _b.next(); !_c.done; _c = _b.next()) {
|
94 | var _d = tslib_1.__read(_c.value, 2), fileName = _d[0], oldVersion = _d[1];
|
95 | if (this.project.getScriptVersion(fileName) !== oldVersion) {
|
96 | modifiedFiles.add(fileName);
|
97 | }
|
98 | }
|
99 | }
|
100 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
101 | finally {
|
102 | try {
|
103 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
104 | }
|
105 | finally { if (e_1) throw e_1.error; }
|
106 | }
|
107 | return modifiedFiles.size > 0 ? modifiedFiles : undefined;
|
108 | };
|
109 | return LanguageServiceAdapter;
|
110 | }());
|
111 | exports.LanguageServiceAdapter = LanguageServiceAdapter;
|
112 | /**
|
113 | * Used to read configuration files.
|
114 | *
|
115 | * A language service parse configuration host is independent of the adapter
|
116 | * because signatures of calls like `FileSystem#readFile` are a bit stricter
|
117 | * than those on the adapter.
|
118 | */
|
119 | var LSParseConfigHost = /** @class */ (function () {
|
120 | function LSParseConfigHost(serverHost) {
|
121 | this.serverHost = serverHost;
|
122 | }
|
123 | LSParseConfigHost.prototype.exists = function (path) {
|
124 | return this.serverHost.fileExists(path) || this.serverHost.directoryExists(path);
|
125 | };
|
126 | LSParseConfigHost.prototype.readFile = function (path) {
|
127 | var content = this.serverHost.readFile(path);
|
128 | if (content === undefined) {
|
129 | throw new Error("LanguageServiceFS#readFile called on unavailable file " + path);
|
130 | }
|
131 | return content;
|
132 | };
|
133 | LSParseConfigHost.prototype.lstat = function (path) {
|
134 | var _this = this;
|
135 | return {
|
136 | isFile: function () {
|
137 | return _this.serverHost.fileExists(path);
|
138 | },
|
139 | isDirectory: function () {
|
140 | return _this.serverHost.directoryExists(path);
|
141 | },
|
142 | isSymbolicLink: function () {
|
143 | throw new Error("LanguageServiceFS#lstat#isSymbolicLink not implemented");
|
144 | },
|
145 | };
|
146 | };
|
147 | LSParseConfigHost.prototype.pwd = function () {
|
148 | return this.serverHost.getCurrentDirectory();
|
149 | };
|
150 | LSParseConfigHost.prototype.extname = function (path) {
|
151 | return p.extname(path);
|
152 | };
|
153 | LSParseConfigHost.prototype.resolve = function () {
|
154 | var paths = [];
|
155 | for (var _i = 0; _i < arguments.length; _i++) {
|
156 | paths[_i] = arguments[_i];
|
157 | }
|
158 | return p.resolve.apply(p, tslib_1.__spread(paths));
|
159 | };
|
160 | LSParseConfigHost.prototype.dirname = function (file) {
|
161 | return p.dirname(file);
|
162 | };
|
163 | LSParseConfigHost.prototype.join = function (basePath) {
|
164 | var paths = [];
|
165 | for (var _i = 1; _i < arguments.length; _i++) {
|
166 | paths[_i - 1] = arguments[_i];
|
167 | }
|
168 | return p.join.apply(p, tslib_1.__spread([basePath], paths));
|
169 | };
|
170 | return LSParseConfigHost;
|
171 | }());
|
172 | exports.LSParseConfigHost = LSParseConfigHost;
|
173 | });
|
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"]} |
\ | No newline at end of file |