mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
vscode: renamed langServer to server
This commit is contained in:
parent
f61134e198
commit
80d5ba68da
3 changed files with 22 additions and 22 deletions
|
@ -2,7 +2,7 @@ import * as lc from 'vscode-languageclient';
|
||||||
import * as vscode from 'vscode';
|
import * as vscode from 'vscode';
|
||||||
|
|
||||||
import { Config } from './config';
|
import { Config } from './config';
|
||||||
import { ensureLangServerBinary } from './installation/lang_server';
|
import { ensureServerBinary } from './installation/server';
|
||||||
import { CallHierarchyFeature } from 'vscode-languageclient/lib/callHierarchy.proposed';
|
import { CallHierarchyFeature } from 'vscode-languageclient/lib/callHierarchy.proposed';
|
||||||
|
|
||||||
export async function createClient(config: Config): Promise<null | lc.LanguageClient> {
|
export async function createClient(config: Config): Promise<null | lc.LanguageClient> {
|
||||||
|
@ -11,11 +11,11 @@ export async function createClient(config: Config): Promise<null | lc.LanguageCl
|
||||||
// It might be a good idea to test if the uri points to a file.
|
// It might be a good idea to test if the uri points to a file.
|
||||||
const workspaceFolderPath = vscode.workspace.workspaceFolders?.[0]?.uri.fsPath ?? '.';
|
const workspaceFolderPath = vscode.workspace.workspaceFolders?.[0]?.uri.fsPath ?? '.';
|
||||||
|
|
||||||
const langServerPath = await ensureLangServerBinary(config.langServerBinarySource);
|
const serverPath = await ensureServerBinary(config.serverBinarySource);
|
||||||
if (!langServerPath) return null;
|
if (!serverPath) return null;
|
||||||
|
|
||||||
const run: lc.Executable = {
|
const run: lc.Executable = {
|
||||||
command: langServerPath,
|
command: serverPath,
|
||||||
options: { cwd: workspaceFolderPath },
|
options: { cwd: workspaceFolderPath },
|
||||||
};
|
};
|
||||||
const serverOptions: lc.ServerOptions = {
|
const serverOptions: lc.ServerOptions = {
|
||||||
|
|
|
@ -68,7 +68,7 @@ export class Config {
|
||||||
* `platform` on GitHub releases. (It is also stored under the same name when
|
* `platform` on GitHub releases. (It is also stored under the same name when
|
||||||
* downloaded by the extension).
|
* downloaded by the extension).
|
||||||
*/
|
*/
|
||||||
get prebuiltLangServerFileName(): null | string {
|
get prebuiltServerFileName(): null | string {
|
||||||
// See possible `arch` values here:
|
// See possible `arch` values here:
|
||||||
// https://nodejs.org/api/process.html#process_process_arch
|
// https://nodejs.org/api/process.html#process_process_arch
|
||||||
|
|
||||||
|
@ -98,17 +98,17 @@ export class Config {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
get langServerBinarySource(): null | BinarySource {
|
get serverBinarySource(): null | BinarySource {
|
||||||
const langServerPath = RA_LSP_DEBUG ?? this.cfg.get<null | string>("raLspServerPath");
|
const serverPath = RA_LSP_DEBUG ?? this.cfg.get<null | string>("raLspServerPath");
|
||||||
|
|
||||||
if (langServerPath) {
|
if (serverPath) {
|
||||||
return {
|
return {
|
||||||
type: BinarySource.Type.ExplicitPath,
|
type: BinarySource.Type.ExplicitPath,
|
||||||
path: Config.replaceTildeWithHomeDir(langServerPath)
|
path: Config.replaceTildeWithHomeDir(serverPath)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const prebuiltBinaryName = this.prebuiltLangServerFileName;
|
const prebuiltBinaryName = this.prebuiltServerFileName;
|
||||||
|
|
||||||
if (!prebuiltBinaryName) return null;
|
if (!prebuiltBinaryName) return null;
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ import { BinarySource } from "./interfaces";
|
||||||
import { fetchLatestArtifactReleaseInfo } from "./fetch_latest_artifact_release_info";
|
import { fetchLatestArtifactReleaseInfo } from "./fetch_latest_artifact_release_info";
|
||||||
import { downloadFile } from "./download_file";
|
import { downloadFile } from "./download_file";
|
||||||
|
|
||||||
export async function downloadLatestLangServer(
|
export async function downloadLatestServer(
|
||||||
{file: artifactFileName, dir: installationDir, repo}: BinarySource.GithubRelease
|
{file: artifactFileName, dir: installationDir, repo}: BinarySource.GithubRelease
|
||||||
) {
|
) {
|
||||||
const { releaseName, downloadUrl } = (await fetchLatestArtifactReleaseInfo(
|
const { releaseName, downloadUrl } = (await fetchLatestArtifactReleaseInfo(
|
||||||
|
@ -53,11 +53,11 @@ export async function downloadLatestLangServer(
|
||||||
);
|
);
|
||||||
console.timeEnd("Downloading ra_lsp_server");
|
console.timeEnd("Downloading ra_lsp_server");
|
||||||
}
|
}
|
||||||
export async function ensureLangServerBinary(
|
export async function ensureServerBinary(
|
||||||
langServerSource: null | BinarySource
|
serverSource: null | BinarySource
|
||||||
): Promise<null | string> {
|
): Promise<null | string> {
|
||||||
|
|
||||||
if (!langServerSource) {
|
if (!serverSource) {
|
||||||
vscode.window.showErrorMessage(
|
vscode.window.showErrorMessage(
|
||||||
"Unfortunately we don't ship binaries for your platform yet. " +
|
"Unfortunately we don't ship binaries for your platform yet. " +
|
||||||
"You need to manually clone rust-analyzer repository and " +
|
"You need to manually clone rust-analyzer repository and " +
|
||||||
|
@ -69,21 +69,21 @@ export async function ensureLangServerBinary(
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (langServerSource.type) {
|
switch (serverSource.type) {
|
||||||
case BinarySource.Type.ExplicitPath: {
|
case BinarySource.Type.ExplicitPath: {
|
||||||
if (isBinaryAvailable(langServerSource.path)) {
|
if (isBinaryAvailable(serverSource.path)) {
|
||||||
return langServerSource.path;
|
return serverSource.path;
|
||||||
}
|
}
|
||||||
|
|
||||||
vscode.window.showErrorMessage(
|
vscode.window.showErrorMessage(
|
||||||
`Unable to run ${langServerSource.path} binary. ` +
|
`Unable to run ${serverSource.path} binary. ` +
|
||||||
`To use the pre-built language server, set "rust-analyzer.raLspServerPath" ` +
|
`To use the pre-built language server, set "rust-analyzer.raLspServerPath" ` +
|
||||||
"value to `null` or remove it from the settings to use it by default."
|
"value to `null` or remove it from the settings to use it by default."
|
||||||
);
|
);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
case BinarySource.Type.GithubRelease: {
|
case BinarySource.Type.GithubRelease: {
|
||||||
const prebuiltBinaryPath = path.join(langServerSource.dir, langServerSource.file);
|
const prebuiltBinaryPath = path.join(serverSource.dir, serverSource.file);
|
||||||
|
|
||||||
if (isBinaryAvailable(prebuiltBinaryPath)) {
|
if (isBinaryAvailable(prebuiltBinaryPath)) {
|
||||||
return prebuiltBinaryPath;
|
return prebuiltBinaryPath;
|
||||||
|
@ -97,10 +97,10 @@ export async function ensureLangServerBinary(
|
||||||
if (userResponse !== "Download now") return null;
|
if (userResponse !== "Download now") return null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await downloadLatestLangServer(langServerSource);
|
await downloadLatestServer(serverSource);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
vscode.window.showErrorMessage(
|
vscode.window.showErrorMessage(
|
||||||
`Failed to download language server from ${langServerSource.repo.name} ` +
|
`Failed to download language server from ${serverSource.repo.name} ` +
|
||||||
`GitHub repository: ${err.message}`
|
`GitHub repository: ${err.message}`
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ export async function ensureLangServerBinary(
|
||||||
|
|
||||||
if (!isBinaryAvailable(prebuiltBinaryPath)) assert(false,
|
if (!isBinaryAvailable(prebuiltBinaryPath)) assert(false,
|
||||||
`Downloaded language server binary is not functional.` +
|
`Downloaded language server binary is not functional.` +
|
||||||
`Downloaded from: ${JSON.stringify(langServerSource)}`
|
`Downloaded from: ${JSON.stringify(serverSource)}`
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue