@vue/language-server 3.0.7-alpha.1 → 3.0.7

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.
Files changed (2) hide show
  1. package/index.js +5 -156
  2. package/package.json +5 -5
package/index.js CHANGED
@@ -1,14 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const language_server_1 = require("@volar/language-server");
4
3
  const simpleProject_1 = require("@volar/language-server/lib/project/simpleProject");
5
4
  const node_1 = require("@volar/language-server/node");
6
5
  const language_core_1 = require("@vue/language-core");
7
6
  const language_service_1 = require("@vue/language-service");
8
7
  const ts = require("typescript");
9
8
  const vscode_uri_1 = require("vscode-uri");
10
- const reactivityAnalyze_1 = require("./lib/reactivityAnalyze");
11
- const reactivityAnalyzeLS_1 = require("./lib/reactivityAnalyzeLS");
12
9
  const connection = (0, node_1.createConnection)();
13
10
  const server = (0, node_1.createServer)(connection);
14
11
  const tsserverRequestHandlers = new Map();
@@ -102,8 +99,11 @@ connection.onInitialize(params => {
102
99
  getImportPathForFile(...args) {
103
100
  return sendTsServerRequest('_vue:getImportPathForFile', args);
104
101
  },
105
- getPropertiesAtLocation(...args) {
106
- return sendTsServerRequest('_vue:getPropertiesAtLocation', args);
102
+ getReactiveReferences(...args) {
103
+ return sendTsServerRequest('_vue:getReactiveReferences', args);
104
+ },
105
+ isRefAtPosition(...args) {
106
+ return sendTsServerRequest('_vue:isRefAtPosition', args);
107
107
  },
108
108
  getDocumentHighlights(fileName, position) {
109
109
  return sendTsServerRequest('_vue:documentHighlights-full', {
@@ -158,155 +158,4 @@ connection.onInitialize(params => {
158
158
  });
159
159
  connection.onInitialized(server.initialized);
160
160
  connection.onShutdown(server.shutdown);
161
- connection.onRequest('vue/interpolationRanges', async (params) => {
162
- const uri = vscode_uri_1.URI.parse(params.textDocument.uri);
163
- const languageService = await server.project.getLanguageService(uri);
164
- if (languageService) {
165
- const sourceFile = languageService.context.language.scripts.get(uri);
166
- if (sourceFile?.generated) {
167
- const ranges = [];
168
- for (const code of (0, language_core_1.forEachEmbeddedCode)(sourceFile.generated.root)) {
169
- const codeText = code.snapshot.getText(0, code.snapshot.getLength());
170
- if ((code.id.startsWith('template_inline_ts_')
171
- && codeText.startsWith('0 +')
172
- && codeText.endsWith('+ 0;'))
173
- || (code.id.startsWith('style_') && code.id.endsWith('_inline_ts'))) {
174
- for (const mapping of code.mappings) {
175
- for (let i = 0; i < mapping.sourceOffsets.length; i++) {
176
- ranges.push([
177
- mapping.sourceOffsets[i],
178
- mapping.sourceOffsets[i] + mapping.lengths[i],
179
- ]);
180
- }
181
- }
182
- }
183
- }
184
- return ranges;
185
- }
186
- }
187
- return [];
188
- });
189
- const cacheDocuments = new Map();
190
- connection.onRequest('vue/reactivityAnalyze', async (params) => {
191
- if (params.syncDocument) {
192
- const document = language_server_1.TextDocument.create(params.textDocument.uri, params.syncDocument.languageId, 0, params.syncDocument.content);
193
- const snapshot = ts.ScriptSnapshot.fromString(params.syncDocument.content);
194
- cacheDocuments.set(params.textDocument.uri, [document, snapshot]);
195
- }
196
- const uri = vscode_uri_1.URI.parse(params.textDocument.uri);
197
- const languageService = await server.project.getLanguageService(uri);
198
- const sourceScript = languageService.context.language.scripts.get(uri);
199
- let document;
200
- let snapshot;
201
- if (sourceScript) {
202
- document = languageService.context.documents.get(sourceScript.id, sourceScript.languageId, sourceScript.snapshot);
203
- snapshot = sourceScript.snapshot;
204
- }
205
- else if (cacheDocuments.has(params.textDocument.uri)) {
206
- const [doc, snap] = cacheDocuments.get(params.textDocument.uri);
207
- document = doc;
208
- snapshot = snap;
209
- }
210
- if (!document || !snapshot) {
211
- return;
212
- }
213
- let offset = document.offsetAt(params.position);
214
- if (sourceScript?.generated) {
215
- const serviceScript = sourceScript.generated.languagePlugin.typescript?.getServiceScript(sourceScript.generated.root);
216
- if (!serviceScript) {
217
- return;
218
- }
219
- const map = languageService.context.language.maps.get(serviceScript.code, sourceScript);
220
- let embeddedOffset;
221
- for (const [mapped, mapping] of map.toGeneratedLocation(offset)) {
222
- if ((0, language_core_1.isReferencesEnabled)(mapping.data)) {
223
- embeddedOffset = mapped;
224
- break;
225
- }
226
- }
227
- if (embeddedOffset === undefined) {
228
- return;
229
- }
230
- offset = embeddedOffset;
231
- const embeddedUri = languageService.context.encodeEmbeddedDocumentUri(sourceScript.id, serviceScript.code.id);
232
- document = languageService.context.documents.get(embeddedUri, serviceScript.code.languageId, serviceScript.code.snapshot);
233
- snapshot = serviceScript.code.snapshot;
234
- }
235
- const { languageService: tsLs, fileName } = (0, reactivityAnalyzeLS_1.getLanguageService)(ts, snapshot, document.languageId);
236
- const result = (0, reactivityAnalyze_1.analyze)(ts, tsLs, fileName, offset);
237
- if (!result) {
238
- return;
239
- }
240
- const subscribers = [];
241
- const dependencies = [];
242
- if (sourceScript?.generated) {
243
- const serviceScript = sourceScript.generated.languagePlugin.typescript?.getServiceScript(sourceScript.generated.root);
244
- if (!serviceScript) {
245
- return;
246
- }
247
- const docs = [
248
- languageService.context.documents.get(sourceScript.id, sourceScript.languageId, sourceScript.snapshot),
249
- document,
250
- languageService.context.language.maps.get(serviceScript.code, sourceScript),
251
- ];
252
- for (const dependency of result.dependencies) {
253
- let start = document.positionAt(dependency.getStart(result.sourceFile));
254
- let end = document.positionAt(dependency.getEnd());
255
- if (ts.isBlock(dependency) && dependency.statements.length) {
256
- const { statements } = dependency;
257
- start = document.positionAt(statements[0].getStart(result.sourceFile));
258
- end = document.positionAt(statements[statements.length - 1].getEnd());
259
- }
260
- const sourceRange = (0, language_service_1.getSourceRange)(docs, { start, end });
261
- if (sourceRange) {
262
- dependencies.push(sourceRange);
263
- }
264
- }
265
- for (const subscriber of result.subscribers) {
266
- if (!subscriber.sideEffectInfo) {
267
- continue;
268
- }
269
- let start = document.positionAt(subscriber.sideEffectInfo.handler.getStart(result.sourceFile));
270
- let end = document.positionAt(subscriber.sideEffectInfo.handler.getEnd());
271
- if (ts.isBlock(subscriber.sideEffectInfo.handler) && subscriber.sideEffectInfo.handler.statements.length) {
272
- const { statements } = subscriber.sideEffectInfo.handler;
273
- start = document.positionAt(statements[0].getStart(result.sourceFile));
274
- end = document.positionAt(statements[statements.length - 1].getEnd());
275
- }
276
- const sourceRange = (0, language_service_1.getSourceRange)(docs, { start, end });
277
- if (sourceRange) {
278
- subscribers.push(sourceRange);
279
- }
280
- }
281
- }
282
- else {
283
- for (const dependency of result.dependencies) {
284
- let start = document.positionAt(dependency.getStart(result.sourceFile));
285
- let end = document.positionAt(dependency.getEnd());
286
- if (ts.isBlock(dependency) && dependency.statements.length) {
287
- const { statements } = dependency;
288
- start = document.positionAt(statements[0].getStart(result.sourceFile));
289
- end = document.positionAt(statements[statements.length - 1].getEnd());
290
- }
291
- dependencies.push({ start, end });
292
- }
293
- for (const subscriber of result.subscribers) {
294
- if (!subscriber.sideEffectInfo) {
295
- continue;
296
- }
297
- let start = document.positionAt(subscriber.sideEffectInfo.handler.getStart(result.sourceFile));
298
- let end = document.positionAt(subscriber.sideEffectInfo.handler.getEnd());
299
- if (ts.isBlock(subscriber.sideEffectInfo.handler) && subscriber.sideEffectInfo.handler.statements.length) {
300
- const { statements } = subscriber.sideEffectInfo.handler;
301
- start = document.positionAt(statements[0].getStart(result.sourceFile));
302
- end = document.positionAt(statements[statements.length - 1].getEnd());
303
- }
304
- subscribers.push({ start, end });
305
- }
306
- }
307
- return {
308
- subscribers,
309
- dependencies,
310
- };
311
- });
312
161
  //# sourceMappingURL=index.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vue/language-server",
3
- "version": "3.0.7-alpha.1",
3
+ "version": "3.0.7",
4
4
  "license": "MIT",
5
5
  "files": [
6
6
  "**/*.js",
@@ -17,9 +17,9 @@
17
17
  },
18
18
  "dependencies": {
19
19
  "@volar/language-server": "2.4.23",
20
- "@vue/language-core": "3.0.7-alpha.1",
21
- "@vue/language-service": "3.0.7-alpha.1",
22
- "@vue/typescript-plugin": "3.0.7-alpha.1",
20
+ "@vue/language-core": "3.0.7",
21
+ "@vue/language-service": "3.0.7",
22
+ "@vue/typescript-plugin": "3.0.7",
23
23
  "vscode-uri": "^3.0.8"
24
24
  },
25
25
  "peerDependencies": {
@@ -29,5 +29,5 @@
29
29
  "@typescript/server-harness": "latest",
30
30
  "@volar/test-utils": "2.4.23"
31
31
  },
32
- "gitHead": "320fc626c871e9ff17c0e4e92ea7ddb0c7641f34"
32
+ "gitHead": "6022b75534487f8a031dfc61a7879f900b64d414"
33
33
  }