@vue/language-server 2.2.8 → 3.0.0-alpha.2

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.d.ts CHANGED
@@ -1,4 +1,3 @@
1
1
  export * from './lib/types';
2
- export * from './lib/initialize';
3
2
  export * from '@volar/language-server/lib/types';
4
3
  export * from '@vue/language-service/lib/types';
package/index.js CHANGED
@@ -15,7 +15,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./lib/types"), exports);
18
- __exportStar(require("./lib/initialize"), exports);
19
18
  // export types of parent package
20
19
  __exportStar(require("@volar/language-server/lib/types"), exports);
21
20
  // only export types of depend packages
package/lib/types.d.ts CHANGED
@@ -1,9 +1,7 @@
1
1
  export type VueInitializationOptions = {
2
2
  typescript: {
3
3
  tsdk: string;
4
- };
5
- vue?: {
6
- hybridMode?: boolean;
4
+ tsserverRequestCommand?: string;
7
5
  };
8
6
  };
9
7
  export * from '@volar/language-server/lib/types';
package/node.js CHANGED
@@ -1,39 +1,147 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ const simpleProject_1 = require("@volar/language-server/lib/project/simpleProject");
3
4
  const node_1 = require("@volar/language-server/node");
4
5
  const language_core_1 = require("@vue/language-core");
5
6
  const language_service_1 = require("@vue/language-service");
6
- const namedPipeClient = require("@vue/typescript-plugin/lib/client");
7
- const hybridModeProject_1 = require("./lib/hybridModeProject");
8
- const initialize_1 = require("./lib/initialize");
7
+ const vscode_uri_1 = require("vscode-uri");
9
8
  const connection = (0, node_1.createConnection)();
10
9
  const server = (0, node_1.createServer)(connection);
11
10
  connection.listen();
12
11
  connection.onInitialize(params => {
13
12
  const options = params.initializationOptions;
14
- const { typescript: ts, diagnosticMessages } = (0, node_1.loadTsdkByPath)(options.typescript.tsdk, params.locale);
15
- const hybridMode = options.vue?.hybridMode ?? true;
16
- if (hybridMode) {
17
- return server.initialize(params, (0, hybridModeProject_1.createHybridModeProject)(({ asFileName, configFileName }) => {
18
- const commandLine = configFileName
19
- ? (0, language_core_1.createParsedCommandLine)(ts, ts.sys, configFileName)
20
- : {
21
- vueOptions: (0, language_core_1.getDefaultCompilerOptions)(),
22
- options: ts.getDefaultCompilerOptions(),
23
- };
24
- commandLine.vueOptions.__test = params.initializationOptions.typescript.disableAutoImportCache;
25
- return {
26
- languagePlugins: [
27
- (0, language_core_1.createVueLanguagePlugin)(ts, commandLine.options, commandLine.vueOptions, asFileName),
28
- ],
29
- setup({ project }) {
30
- project.vue = { compilerOptions: commandLine.vueOptions };
31
- },
32
- };
33
- }), (0, language_service_1.getHybridModeLanguageServicePlugins)(ts, namedPipeClient));
13
+ if (!options.typescript?.tsdk) {
14
+ throw new Error('typescript.tsdk is required');
15
+ }
16
+ if (!options.typescript?.tsserverRequestCommand) {
17
+ connection.console.warn('typescript.tsserverRequestCommand is required since >= 3.0 for complete TS features');
34
18
  }
35
- else {
36
- return (0, initialize_1.initialize)(server, params, ts, diagnosticMessages);
19
+ const { typescript: ts } = (0, node_1.loadTsdkByPath)(options.typescript.tsdk, params.locale);
20
+ const tsconfigProjects = (0, language_service_1.createUriMap)();
21
+ const file2ProjectInfo = new Map();
22
+ server.fileWatcher.onDidChangeWatchedFiles(({ changes }) => {
23
+ for (const change of changes) {
24
+ const changeUri = vscode_uri_1.URI.parse(change.uri);
25
+ if (tsconfigProjects.has(changeUri)) {
26
+ tsconfigProjects.get(changeUri).dispose();
27
+ tsconfigProjects.delete(changeUri);
28
+ file2ProjectInfo.clear();
29
+ }
30
+ }
31
+ });
32
+ let simpleLs;
33
+ return server.initialize(params, {
34
+ setup() { },
35
+ async getLanguageService(uri) {
36
+ if (uri.scheme === 'file' && options.typescript.tsserverRequestCommand) {
37
+ const fileName = uri.fsPath.replace(/\\/g, '/');
38
+ let projectInfoPromise = file2ProjectInfo.get(fileName);
39
+ if (!projectInfoPromise) {
40
+ projectInfoPromise = sendTsRequest(ts.server.protocol.CommandTypes.ProjectInfo, {
41
+ file: fileName,
42
+ needFileNameList: false,
43
+ });
44
+ file2ProjectInfo.set(fileName, projectInfoPromise);
45
+ }
46
+ const projectInfo = await projectInfoPromise;
47
+ if (projectInfo) {
48
+ const { configFileName } = projectInfo;
49
+ let ls = tsconfigProjects.get(vscode_uri_1.URI.file(configFileName));
50
+ if (!ls) {
51
+ ls = createLs(server, configFileName);
52
+ tsconfigProjects.set(vscode_uri_1.URI.file(configFileName), ls);
53
+ }
54
+ return ls;
55
+ }
56
+ }
57
+ return simpleLs ??= createLs(server, undefined);
58
+ },
59
+ getExistingLanguageServices() {
60
+ return Promise.all([
61
+ ...tsconfigProjects.values(),
62
+ simpleLs,
63
+ ].filter(promise => !!promise));
64
+ },
65
+ reload() {
66
+ for (const ls of [
67
+ ...tsconfigProjects.values(),
68
+ simpleLs,
69
+ ]) {
70
+ ls?.dispose();
71
+ }
72
+ tsconfigProjects.clear();
73
+ simpleLs = undefined;
74
+ },
75
+ }, (0, language_service_1.getHybridModeLanguageServicePlugins)(ts, options.typescript.tsserverRequestCommand ? {
76
+ collectExtractProps(...args) {
77
+ return sendTsRequest('vue:collectExtractProps', args);
78
+ },
79
+ getComponentDirectives(...args) {
80
+ return sendTsRequest('vue:getComponentDirectives', args);
81
+ },
82
+ getComponentEvents(...args) {
83
+ return sendTsRequest('vue:getComponentEvents', args);
84
+ },
85
+ getComponentNames(...args) {
86
+ return sendTsRequest('vue:getComponentNames', args);
87
+ },
88
+ getComponentProps(...args) {
89
+ return sendTsRequest('vue:getComponentProps', args);
90
+ },
91
+ getElementAttrs(...args) {
92
+ return sendTsRequest('vue:getElementAttrs', args);
93
+ },
94
+ getElementNames(...args) {
95
+ return sendTsRequest('vue:getElementNames', args);
96
+ },
97
+ getImportPathForFile(...args) {
98
+ return sendTsRequest('vue:getImportPathForFile', args);
99
+ },
100
+ getPropertiesAtLocation(...args) {
101
+ return sendTsRequest('vue:getPropertiesAtLocation', args);
102
+ },
103
+ getDocumentHighlights(fileName, position) {
104
+ return sendTsRequest('documentHighlights-full', // internal command
105
+ {
106
+ file: fileName,
107
+ ...{ position },
108
+ filesToSearch: [fileName],
109
+ });
110
+ },
111
+ async getQuickInfoAtPosition(fileName, { line, character }) {
112
+ const result = await sendTsRequest(ts.server.protocol.CommandTypes.Quickinfo, {
113
+ file: fileName,
114
+ line: line + 1,
115
+ offset: character + 1,
116
+ });
117
+ return ts.displayPartsToString(result?.displayParts ?? []);
118
+ },
119
+ } : undefined));
120
+ function sendTsRequest(command, args) {
121
+ return connection.sendRequest(options.typescript.tsserverRequestCommand, [command, args]);
122
+ }
123
+ function createLs(server, tsconfig) {
124
+ const commonLine = tsconfig
125
+ ? (0, language_core_1.createParsedCommandLine)(ts, ts.sys, tsconfig)
126
+ : {
127
+ options: ts.getDefaultCompilerOptions(),
128
+ vueOptions: (0, language_core_1.getDefaultCompilerOptions)(),
129
+ };
130
+ const language = (0, language_core_1.createLanguage)([
131
+ {
132
+ getLanguageId: uri => server.documents.get(uri)?.languageId,
133
+ },
134
+ (0, language_core_1.createVueLanguagePlugin)(ts, commonLine.options, commonLine.vueOptions, uri => uri.fsPath.replace(/\\/g, '/')),
135
+ ], (0, language_service_1.createUriMap)(), uri => {
136
+ const document = server.documents.get(uri);
137
+ if (document) {
138
+ language.scripts.set(uri, document.getSnapshot(), document.languageId);
139
+ }
140
+ else {
141
+ language.scripts.delete(uri);
142
+ }
143
+ });
144
+ return (0, language_service_1.createLanguageService)(language, server.languageServicePlugins, (0, simpleProject_1.createLanguageServiceEnvironment)(server, [...server.workspaceFolders.all]), { vue: { compilerOptions: commonLine.vueOptions } });
37
145
  }
38
146
  });
39
147
  connection.onInitialized(server.initialized);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vue/language-server",
3
- "version": "2.2.8",
3
+ "version": "3.0.0-alpha.2",
4
4
  "license": "MIT",
5
5
  "files": [
6
6
  "**/*.js",
@@ -19,11 +19,14 @@
19
19
  "@volar/language-core": "~2.4.11",
20
20
  "@volar/language-server": "~2.4.11",
21
21
  "@volar/test-utils": "~2.4.11",
22
- "@vue/language-core": "2.2.8",
23
- "@vue/language-service": "2.2.8",
24
- "@vue/typescript-plugin": "2.2.8",
22
+ "@vue/language-core": "3.0.0-alpha.2",
23
+ "@vue/language-service": "3.0.0-alpha.2",
24
+ "@vue/typescript-plugin": "3.0.0-alpha.2",
25
25
  "vscode-languageserver-protocol": "^3.17.5",
26
26
  "vscode-uri": "^3.0.8"
27
27
  },
28
- "gitHead": "cdf00e6f19971260607ea2347924b94126a254fc"
28
+ "devDependencies": {
29
+ "@typescript/server-harness": "latest"
30
+ },
31
+ "gitHead": "79247b7c24b7202ec676723440fdb36c38e6d450"
29
32
  }