rust-analyzer/editors/code/src/lsp_ext.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

168 lines
5.5 KiB
TypeScript
Raw Normal View History

/**
2020-08-28 18:55:24 +00:00
* This file mirrors `crates/rust-analyzer/src/lsp_ext.rs` declarations.
*/
import * as lc from "vscode-languageclient";
2023-01-23 14:26:28 +00:00
// rust-analyzer overrides
export const hover = new lc.RequestType<
HoverParams,
(lc.Hover & { actions: CommandLinkGroup[] }) | null,
void
>("textDocument/hover");
export type HoverParams = { position: lc.Position | lc.Range } & Omit<
lc.TextDocumentPositionParams,
"position"
> &
lc.WorkDoneProgressParams;
export type CommandLink = {
/**
* A tooltip for the command, when represented in the UI.
*/
tooltip?: string;
} & lc.Command;
export type CommandLinkGroup = {
title?: string;
commands: CommandLink[];
};
// rust-analyzer extensions
export const analyzerStatus = new lc.RequestType<AnalyzerStatusParams, string, void>(
"rust-analyzer/analyzerStatus"
);
2023-01-23 14:26:28 +00:00
export const cancelFlycheck = new lc.NotificationType0("rust-analyzer/cancelFlycheck");
export const clearFlycheck = new lc.NotificationType0("rust-analyzer/clearFlycheck");
export const expandMacro = new lc.RequestType<ExpandMacroParams, ExpandedMacro | null, void>(
"rust-analyzer/expandMacro"
2021-04-06 11:16:35 +00:00
);
2023-01-23 14:26:28 +00:00
export const memoryUsage = new lc.RequestType0<string, void>("rust-analyzer/memoryUsage");
export const openServerLogs = new lc.NotificationType0("rust-analyzer/openServerLogs");
2023-01-23 14:26:28 +00:00
export const relatedTests = new lc.RequestType<lc.TextDocumentPositionParams, TestInfo[], void>(
"rust-analyzer/relatedTests"
);
2020-09-17 10:31:42 +00:00
export const reloadWorkspace = new lc.RequestType0<null, void>("rust-analyzer/reloadWorkspace");
export const rebuildProcMacros = new lc.RequestType0<null, void>("rust-analyzer/rebuildProcMacros");
2023-01-23 14:26:28 +00:00
export const runFlycheck = new lc.NotificationType<{
textDocument: lc.TextDocumentIdentifier | null;
}>("rust-analyzer/runFlycheck");
export const shuffleCrateGraph = new lc.RequestType0<null, void>("rust-analyzer/shuffleCrateGraph");
export const syntaxTree = new lc.RequestType<SyntaxTreeParams, string, void>(
"rust-analyzer/syntaxTree"
);
2023-01-23 14:26:28 +00:00
export const viewCrateGraph = new lc.RequestType<ViewCrateGraphParams, string, void>(
"rust-analyzer/viewCrateGraph"
);
export const viewFileText = new lc.RequestType<lc.TextDocumentIdentifier, string, void>(
"rust-analyzer/viewFileText"
);
2023-01-23 14:26:28 +00:00
export const viewHir = new lc.RequestType<lc.TextDocumentPositionParams, string, void>(
"rust-analyzer/viewHir"
);
export const viewMir = new lc.RequestType<lc.TextDocumentPositionParams, string, void>(
"rust-analyzer/viewMir"
);
2021-05-21 21:59:52 +00:00
export const viewItemTree = new lc.RequestType<ViewItemTreeParams, string, void>(
"rust-analyzer/viewItemTree"
);
2023-01-23 14:26:28 +00:00
export type AnalyzerStatusParams = { textDocument?: lc.TextDocumentIdentifier };
2023-01-23 14:26:28 +00:00
export type ExpandMacroParams = {
textDocument: lc.TextDocumentIdentifier;
position: lc.Position;
2023-01-23 14:26:28 +00:00
};
export type ExpandedMacro = {
name: string;
expansion: string;
2023-01-23 14:26:28 +00:00
};
export type TestInfo = { runnable: Runnable };
export type SyntaxTreeParams = {
textDocument: lc.TextDocumentIdentifier;
2023-01-23 14:26:28 +00:00
range: lc.Range | null;
};
export type ViewCrateGraphParams = { full: boolean };
export type ViewItemTreeParams = { textDocument: lc.TextDocumentIdentifier };
2023-01-23 14:26:28 +00:00
// experimental extensions
export const joinLines = new lc.RequestType<JoinLinesParams, lc.TextEdit[], void>(
"experimental/joinLines"
);
export const matchingBrace = new lc.RequestType<MatchingBraceParams, lc.Position[], void>(
"experimental/matchingBrace"
);
2023-01-23 14:26:28 +00:00
export const moveItem = new lc.RequestType<MoveItemParams, lc.TextEdit[], void>(
"experimental/moveItem"
);
export const onEnter = new lc.RequestType<lc.TextDocumentPositionParams, lc.TextEdit[], void>(
"experimental/onEnter"
);
export const openCargoToml = new lc.RequestType<OpenCargoTomlParams, lc.Location, void>(
"experimental/openCargoToml"
);
export const openDocs = new lc.RequestType<lc.TextDocumentPositionParams, string | void, void>(
"experimental/externalDocs"
);
2021-10-13 22:16:42 +00:00
export const parentModule = new lc.RequestType<
lc.TextDocumentPositionParams,
lc.LocationLink[] | null,
void
>("experimental/parentModule");
2023-01-23 14:26:28 +00:00
export const runnables = new lc.RequestType<RunnablesParams, Runnable[], void>(
"experimental/runnables"
);
2023-01-23 14:26:28 +00:00
export const serverStatus = new lc.NotificationType<ServerStatusParams>(
"experimental/serverStatus"
);
2023-01-23 14:26:28 +00:00
export const ssr = new lc.RequestType<SsrParams, lc.WorkspaceEdit, void>("experimental/ssr");
2023-01-23 14:26:28 +00:00
export type JoinLinesParams = {
textDocument: lc.TextDocumentIdentifier;
2023-01-23 14:26:28 +00:00
ranges: lc.Range[];
};
export type MatchingBraceParams = {
textDocument: lc.TextDocumentIdentifier;
positions: lc.Position[];
};
export type MoveItemParams = {
textDocument: lc.TextDocumentIdentifier;
range: lc.Range;
direction: Direction;
};
export type Direction = "Up" | "Down";
export type OpenCargoTomlParams = {
textDocument: lc.TextDocumentIdentifier;
};
export type Runnable = {
label: string;
2020-06-02 15:22:23 +00:00
location?: lc.LocationLink;
kind: "cargo";
args: {
workspaceRoot?: string;
cargoArgs: string[];
cargoExtraArgs: string[];
2020-06-02 15:22:23 +00:00
executableArgs: string[];
expectTest?: boolean;
overrideCargo?: string;
2020-06-02 15:22:23 +00:00
};
2023-01-23 14:26:28 +00:00
};
export type RunnablesParams = {
2020-11-13 01:48:07 +00:00
textDocument: lc.TextDocumentIdentifier;
2023-01-23 14:26:28 +00:00
position: lc.Position | null;
};
export type ServerStatusParams = {
health: "ok" | "warning" | "error";
quiescent: boolean;
message?: string;
};
export type SsrParams = {
query: string;
parseOnly: boolean;
2021-03-16 15:11:50 +00:00
textDocument: lc.TextDocumentIdentifier;
2023-01-23 14:26:28 +00:00
position: lc.Position;
selections: readonly lc.Range[];
};