@vue/language-server 3.0.0-beta.3 → 3.0.0-beta.5
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/index.js +33 -39
- package/lib/reactionsAnalyze.js +10 -6
- package/lib/reactionsAnalyzeLS.js +7 -4
- package/package.json +7 -7
package/index.js
CHANGED
|
@@ -11,7 +11,13 @@ const reactionsAnalyze_1 = require("./lib/reactionsAnalyze");
|
|
|
11
11
|
const reactionsAnalyzeLS_1 = require("./lib/reactionsAnalyzeLS");
|
|
12
12
|
const connection = (0, node_1.createConnection)();
|
|
13
13
|
const server = (0, node_1.createServer)(connection);
|
|
14
|
+
const tsserverRequestHandlers = new Map();
|
|
15
|
+
let tsserverRequestId = 0;
|
|
14
16
|
connection.listen();
|
|
17
|
+
connection.onNotification('tsserver/response', ([id, res]) => {
|
|
18
|
+
tsserverRequestHandlers.get(id)?.(res);
|
|
19
|
+
tsserverRequestHandlers.delete(id);
|
|
20
|
+
});
|
|
15
21
|
connection.onInitialize(params => {
|
|
16
22
|
const tsconfigProjects = (0, language_service_1.createUriMap)();
|
|
17
23
|
const file2ProjectInfo = new Map();
|
|
@@ -25,13 +31,7 @@ connection.onInitialize(params => {
|
|
|
25
31
|
}
|
|
26
32
|
}
|
|
27
33
|
});
|
|
28
|
-
let
|
|
29
|
-
let tsserverRequestId = 0;
|
|
30
|
-
const tsserverRequestHandlers = new Map();
|
|
31
|
-
connection.onNotification('tsserver/response', ([id, res]) => {
|
|
32
|
-
tsserverRequestHandlers.get(id)?.(res);
|
|
33
|
-
tsserverRequestHandlers.delete(id);
|
|
34
|
-
});
|
|
34
|
+
let simpleLanguageService;
|
|
35
35
|
return server.initialize(params, {
|
|
36
36
|
setup() { },
|
|
37
37
|
async getLanguageService(uri) {
|
|
@@ -39,7 +39,7 @@ connection.onInitialize(params => {
|
|
|
39
39
|
const fileName = uri.fsPath.replace(/\\/g, '/');
|
|
40
40
|
let projectInfoPromise = file2ProjectInfo.get(fileName);
|
|
41
41
|
if (!projectInfoPromise) {
|
|
42
|
-
projectInfoPromise =
|
|
42
|
+
projectInfoPromise = sendTsServerRequest('_vue:' + ts.server.protocol.CommandTypes.ProjectInfo, {
|
|
43
43
|
file: fileName,
|
|
44
44
|
needFileNameList: false,
|
|
45
45
|
});
|
|
@@ -48,69 +48,69 @@ connection.onInitialize(params => {
|
|
|
48
48
|
const projectInfo = await projectInfoPromise;
|
|
49
49
|
if (projectInfo) {
|
|
50
50
|
const { configFileName } = projectInfo;
|
|
51
|
-
let
|
|
52
|
-
if (!
|
|
53
|
-
|
|
54
|
-
tsconfigProjects.set(vscode_uri_1.URI.file(configFileName),
|
|
51
|
+
let languageService = tsconfigProjects.get(vscode_uri_1.URI.file(configFileName));
|
|
52
|
+
if (!languageService) {
|
|
53
|
+
languageService = createProjectLanguageService(server, configFileName);
|
|
54
|
+
tsconfigProjects.set(vscode_uri_1.URI.file(configFileName), languageService);
|
|
55
55
|
}
|
|
56
|
-
return
|
|
56
|
+
return languageService;
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
|
-
return
|
|
59
|
+
return simpleLanguageService ??= createProjectLanguageService(server, undefined);
|
|
60
60
|
},
|
|
61
61
|
getExistingLanguageServices() {
|
|
62
62
|
return Promise.all([
|
|
63
63
|
...tsconfigProjects.values(),
|
|
64
|
-
|
|
64
|
+
simpleLanguageService,
|
|
65
65
|
].filter(promise => !!promise));
|
|
66
66
|
},
|
|
67
67
|
reload() {
|
|
68
|
-
for (const
|
|
69
|
-
|
|
68
|
+
for (const languageService of tsconfigProjects.values()) {
|
|
69
|
+
languageService.dispose();
|
|
70
70
|
}
|
|
71
71
|
tsconfigProjects.clear();
|
|
72
|
-
if (
|
|
73
|
-
|
|
74
|
-
|
|
72
|
+
if (simpleLanguageService) {
|
|
73
|
+
simpleLanguageService.dispose();
|
|
74
|
+
simpleLanguageService = undefined;
|
|
75
75
|
}
|
|
76
76
|
},
|
|
77
77
|
}, (0, language_service_1.createVueLanguageServicePlugins)(ts, {
|
|
78
78
|
collectExtractProps(...args) {
|
|
79
|
-
return
|
|
79
|
+
return sendTsServerRequest('_vue:collectExtractProps', args);
|
|
80
80
|
},
|
|
81
81
|
getComponentDirectives(...args) {
|
|
82
|
-
return
|
|
82
|
+
return sendTsServerRequest('_vue:getComponentDirectives', args);
|
|
83
83
|
},
|
|
84
84
|
getComponentEvents(...args) {
|
|
85
|
-
return
|
|
85
|
+
return sendTsServerRequest('_vue:getComponentEvents', args);
|
|
86
86
|
},
|
|
87
87
|
getComponentNames(...args) {
|
|
88
|
-
return
|
|
88
|
+
return sendTsServerRequest('_vue:getComponentNames', args);
|
|
89
89
|
},
|
|
90
90
|
getComponentProps(...args) {
|
|
91
|
-
return
|
|
91
|
+
return sendTsServerRequest('_vue:getComponentProps', args);
|
|
92
92
|
},
|
|
93
93
|
getElementAttrs(...args) {
|
|
94
|
-
return
|
|
94
|
+
return sendTsServerRequest('_vue:getElementAttrs', args);
|
|
95
95
|
},
|
|
96
96
|
getElementNames(...args) {
|
|
97
|
-
return
|
|
97
|
+
return sendTsServerRequest('_vue:getElementNames', args);
|
|
98
98
|
},
|
|
99
99
|
getImportPathForFile(...args) {
|
|
100
|
-
return
|
|
100
|
+
return sendTsServerRequest('_vue:getImportPathForFile', args);
|
|
101
101
|
},
|
|
102
102
|
getPropertiesAtLocation(...args) {
|
|
103
|
-
return
|
|
103
|
+
return sendTsServerRequest('_vue:getPropertiesAtLocation', args);
|
|
104
104
|
},
|
|
105
105
|
getDocumentHighlights(fileName, position) {
|
|
106
|
-
return
|
|
106
|
+
return sendTsServerRequest('_vue:documentHighlights-full', {
|
|
107
107
|
file: fileName,
|
|
108
108
|
...{ position },
|
|
109
109
|
filesToSearch: [fileName],
|
|
110
110
|
});
|
|
111
111
|
},
|
|
112
112
|
async getQuickInfoAtPosition(fileName, { line, character }) {
|
|
113
|
-
const result = await
|
|
113
|
+
const result = await sendTsServerRequest('_vue:' + ts.server.protocol.CommandTypes.Quickinfo, {
|
|
114
114
|
file: fileName,
|
|
115
115
|
line: line + 1,
|
|
116
116
|
offset: character + 1,
|
|
@@ -118,14 +118,14 @@ connection.onInitialize(params => {
|
|
|
118
118
|
return ts.displayPartsToString(result?.displayParts ?? []);
|
|
119
119
|
},
|
|
120
120
|
}));
|
|
121
|
-
async function
|
|
121
|
+
async function sendTsServerRequest(command, args) {
|
|
122
122
|
return await new Promise(resolve => {
|
|
123
123
|
const requestId = ++tsserverRequestId;
|
|
124
124
|
tsserverRequestHandlers.set(requestId, resolve);
|
|
125
125
|
connection.sendNotification('tsserver/request', [requestId, command, args]);
|
|
126
126
|
});
|
|
127
127
|
}
|
|
128
|
-
function
|
|
128
|
+
function createProjectLanguageService(server, tsconfig) {
|
|
129
129
|
const commonLine = tsconfig
|
|
130
130
|
? (0, language_core_1.createParsedCommandLine)(ts, ts.sys, tsconfig)
|
|
131
131
|
: {
|
|
@@ -151,12 +151,6 @@ connection.onInitialize(params => {
|
|
|
151
151
|
});
|
|
152
152
|
connection.onInitialized(server.initialized);
|
|
153
153
|
connection.onShutdown(server.shutdown);
|
|
154
|
-
connection.onRequest('vue/parseSfc', (params) => {
|
|
155
|
-
const document = server.documents.get(vscode_uri_1.URI.parse(params.textDocument.uri));
|
|
156
|
-
if (document) {
|
|
157
|
-
return (0, language_core_1.parse)(document.getText());
|
|
158
|
-
}
|
|
159
|
-
});
|
|
160
154
|
connection.onRequest('vue/interpolationRanges', async (params) => {
|
|
161
155
|
const uri = vscode_uri_1.URI.parse(params.textDocument.uri);
|
|
162
156
|
const languageService = await server.project.getLanguageService(uri);
|
package/lib/reactionsAnalyze.js
CHANGED
|
@@ -121,7 +121,6 @@ function analyze(ts, languageService, fileName, position) {
|
|
|
121
121
|
}
|
|
122
122
|
node.forEachChild(child => visit(child, needToUse, ts.isPropertyAccessExpression(node) || ts.isElementAccessExpression(node)));
|
|
123
123
|
}
|
|
124
|
-
;
|
|
125
124
|
}
|
|
126
125
|
function findSubscribers(refName, trackKinds, visited = new Set()) {
|
|
127
126
|
return (0, language_core_1.findBindingVars)(ts, refName, sourceFile)
|
|
@@ -180,13 +179,16 @@ function analyze(ts, languageService, fileName, position) {
|
|
|
180
179
|
return result;
|
|
181
180
|
}
|
|
182
181
|
function findSignalByNamePosition(position) {
|
|
183
|
-
return signals.find(ref => ref.bindingInfo && ref.bindingInfo.name.getStart(sourceFile) <= position
|
|
182
|
+
return signals.find(ref => ref.bindingInfo && ref.bindingInfo.name.getStart(sourceFile) <= position
|
|
183
|
+
&& ref.bindingInfo.name.getEnd() >= position);
|
|
184
184
|
}
|
|
185
185
|
function findEffectByEffectHandlerPosition(position) {
|
|
186
|
-
return signals.find(ref => ref.sideEffectInfo && ref.sideEffectInfo.handler.getStart(sourceFile) <= position
|
|
186
|
+
return signals.find(ref => ref.sideEffectInfo && ref.sideEffectInfo.handler.getStart(sourceFile) <= position
|
|
187
|
+
&& ref.sideEffectInfo.handler.getEnd() >= position);
|
|
187
188
|
}
|
|
188
189
|
function findEffectByDepsHandlerPosition(position) {
|
|
189
|
-
return signals.find(ref => ref.trackInfo && ref.trackInfo.depsHandler.getStart(sourceFile) <= position
|
|
190
|
+
return signals.find(ref => ref.trackInfo && ref.trackInfo.depsHandler.getStart(sourceFile) <= position
|
|
191
|
+
&& ref.trackInfo.depsHandler.getEnd() >= position);
|
|
190
192
|
}
|
|
191
193
|
}
|
|
192
194
|
function collect(ts, sourceFile) {
|
|
@@ -200,7 +202,8 @@ function collect(ts, sourceFile) {
|
|
|
200
202
|
const call = node.initializer;
|
|
201
203
|
if (ts.isIdentifier(call.expression)) {
|
|
202
204
|
const callName = call.expression.escapedText;
|
|
203
|
-
if (callName === 'ref' || callName === 'shallowRef' || callName === 'toRef' || callName === 'useTemplateRef'
|
|
205
|
+
if (callName === 'ref' || callName === 'shallowRef' || callName === 'toRef' || callName === 'useTemplateRef'
|
|
206
|
+
|| callName === 'defineModel') {
|
|
204
207
|
signals.push({
|
|
205
208
|
bindingInfo: {
|
|
206
209
|
isRef: true,
|
|
@@ -209,7 +212,8 @@ function collect(ts, sourceFile) {
|
|
|
209
212
|
},
|
|
210
213
|
});
|
|
211
214
|
}
|
|
212
|
-
else if (callName === 'reactive' || callName === 'shallowReactive' || callName === 'defineProps'
|
|
215
|
+
else if (callName === 'reactive' || callName === 'shallowReactive' || callName === 'defineProps'
|
|
216
|
+
|| callName === 'withDefaults') {
|
|
213
217
|
signals.push({
|
|
214
218
|
bindingInfo: {
|
|
215
219
|
isRef: true,
|
|
@@ -20,10 +20,13 @@ const host = {
|
|
|
20
20
|
function getLanguageService(ts, snapshot, languageId) {
|
|
21
21
|
if (currentSnapshot !== snapshot) {
|
|
22
22
|
currentSnapshot = snapshot;
|
|
23
|
-
currentFileName = '/tmp.' + (languageId === 'javascript'
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
23
|
+
currentFileName = '/tmp.' + (languageId === 'javascript'
|
|
24
|
+
? 'js'
|
|
25
|
+
: languageId === 'typescriptreact'
|
|
26
|
+
? 'tsx'
|
|
27
|
+
: languageId === 'javascriptreact'
|
|
28
|
+
? 'jsx'
|
|
29
|
+
: 'ts');
|
|
27
30
|
currentProjectVersion++;
|
|
28
31
|
}
|
|
29
32
|
languageService ??= ts.createLanguageService(host);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vue/language-server",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.5",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"files": [
|
|
6
6
|
"**/*.js",
|
|
@@ -16,10 +16,10 @@
|
|
|
16
16
|
"directory": "packages/language-server"
|
|
17
17
|
},
|
|
18
18
|
"dependencies": {
|
|
19
|
-
"@volar/language-server": "2.4.
|
|
20
|
-
"@vue/language-core": "3.0.0-beta.
|
|
21
|
-
"@vue/language-service": "3.0.0-beta.
|
|
22
|
-
"@vue/typescript-plugin": "3.0.0-beta.
|
|
19
|
+
"@volar/language-server": "2.4.15",
|
|
20
|
+
"@vue/language-core": "3.0.0-beta.5",
|
|
21
|
+
"@vue/language-service": "3.0.0-beta.5",
|
|
22
|
+
"@vue/typescript-plugin": "3.0.0-beta.5",
|
|
23
23
|
"vscode-uri": "^3.0.8"
|
|
24
24
|
},
|
|
25
25
|
"peerDependencies": {
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
},
|
|
28
28
|
"devDependencies": {
|
|
29
29
|
"@typescript/server-harness": "latest",
|
|
30
|
-
"@volar/test-utils": "2.4.
|
|
30
|
+
"@volar/test-utils": "2.4.15"
|
|
31
31
|
},
|
|
32
|
-
"gitHead": "
|
|
32
|
+
"gitHead": "3a4648914c60c90444d939cf762a016a4318ca09"
|
|
33
33
|
}
|