1 | ;
|
2 | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3 | function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4 | return new (P || (P = Promise))(function (resolve, reject) {
|
5 | function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6 | function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7 | function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8 | step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9 | });
|
10 | };
|
11 | Object.defineProperty(exports, "__esModule", { value: true });
|
12 | const assert = require("assert");
|
13 | const convert_1 = require("../convert");
|
14 | const apply_edit_adapter_1 = require("./apply-edit-adapter");
|
15 | const languageclient_1 = require("../languageclient");
|
16 | class CodeActionAdapter {
|
17 | /** @returns A {Boolean} indicating this adapter can adapt the server based on the given serverCapabilities. */
|
18 | static canAdapt(serverCapabilities) {
|
19 | return serverCapabilities.codeActionProvider === true;
|
20 | }
|
21 | /**
|
22 | * Public: Retrieves code actions for a given editor, range, and context (diagnostics). Throws an error if
|
23 | * codeActionProvider is not a registered capability.
|
24 | *
|
25 | * @param connection A {LanguageClientConnection} to the language server that provides highlights.
|
26 | * @param serverCapabilities The {ServerCapabilities} of the language server that will be used.
|
27 | * @param editor The Atom {TextEditor} containing the diagnostics.
|
28 | * @param range The Atom {Range} to fetch code actions for.
|
29 | * @param linterMessages An {Array<linter$Message>} to fetch code actions for. This is typically a list of messages
|
30 | * intersecting `range`.
|
31 | * @returns A {Promise} of an {Array} of {atomIde$CodeAction}s to display.
|
32 | */
|
33 | static getCodeActions(connection, serverCapabilities, linterAdapter, editor, range, linterMessages, filterActions = (actions) => actions, onApply = () => Promise.resolve(true)) {
|
34 | return __awaiter(this, void 0, void 0, function* () {
|
35 | if (linterAdapter == null) {
|
36 | return [];
|
37 | }
|
38 | assert(serverCapabilities.codeActionProvider, "Must have the textDocument/codeAction capability");
|
39 | const params = createCodeActionParams(linterAdapter, editor, range, linterMessages);
|
40 | const actions = filterActions(yield connection.codeAction(params));
|
41 | if (actions === null) {
|
42 | return [];
|
43 | }
|
44 | return actions.map((action) => CodeActionAdapter.createCodeAction(action, connection, onApply));
|
45 | });
|
46 | }
|
47 | static createCodeAction(action, connection, onApply) {
|
48 | return {
|
49 | apply() {
|
50 | return __awaiter(this, void 0, void 0, function* () {
|
51 | if (!(yield onApply(action))) {
|
52 | return;
|
53 | }
|
54 | if (languageclient_1.CodeAction.is(action)) {
|
55 | CodeActionAdapter.applyWorkspaceEdit(action.edit);
|
56 | yield CodeActionAdapter.executeCommand(action.command, connection);
|
57 | }
|
58 | else {
|
59 | yield CodeActionAdapter.executeCommand(action, connection);
|
60 | }
|
61 | });
|
62 | },
|
63 | getTitle() {
|
64 | return Promise.resolve(action.title);
|
65 | },
|
66 | dispose() { },
|
67 | };
|
68 | }
|
69 | static applyWorkspaceEdit(edit) {
|
70 | if (languageclient_1.WorkspaceEdit.is(edit)) {
|
71 | apply_edit_adapter_1.default.onApplyEdit({ edit });
|
72 | }
|
73 | }
|
74 | static executeCommand(command, connection) {
|
75 | return __awaiter(this, void 0, void 0, function* () {
|
76 | if (languageclient_1.Command.is(command)) {
|
77 | yield connection.executeCommand({
|
78 | command: command.command,
|
79 | arguments: command.arguments,
|
80 | });
|
81 | }
|
82 | });
|
83 | }
|
84 | }
|
85 | exports.default = CodeActionAdapter;
|
86 | function createCodeActionParams(linterAdapter, editor, range, linterMessages) {
|
87 | let diagnostics;
|
88 | if (linterMessages.length === 0) {
|
89 | diagnostics = [];
|
90 | }
|
91 | else {
|
92 | // TODO compile time dispatch using function names
|
93 | diagnostics = areLinterMessages(linterMessages)
|
94 | ? linterAdapter.getLSDiagnosticsForMessages(linterMessages)
|
95 | : linterAdapter.getLSDiagnosticsForIdeDiagnostics(linterMessages, editor);
|
96 | }
|
97 | return {
|
98 | textDocument: convert_1.default.editorToTextDocumentIdentifier(editor),
|
99 | range: convert_1.default.atomRangeToLSRange(range),
|
100 | context: {
|
101 | diagnostics,
|
102 | },
|
103 | };
|
104 | }
|
105 | function areLinterMessages(linterMessages) {
|
106 | if ("excerpt" in linterMessages[0]) {
|
107 | return true;
|
108 | }
|
109 | return false;
|
110 | }
|
111 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-action-adapter.js","sourceRoot":"","sources":["../../../lib/adapters/code-action-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as atomIde from \"atom-ide-base\"\nimport * as linter from \"atom/linter\"\nimport LinterPushV2Adapter from \"./linter-push-v2-adapter\"\n/* eslint-disable import/no-deprecated */\nimport IdeDiagnosticAdapter from \"./diagnostic-adapter\"\nimport assert = require(\"assert\")\nimport Convert from \"../convert\"\nimport ApplyEditAdapter from \"./apply-edit-adapter\"\nimport {\n  CodeAction,\n  CodeActionParams,\n  Command,\n  Diagnostic,\n  LanguageClientConnection,\n  ServerCapabilities,\n  WorkspaceEdit,\n} from \"../languageclient\"\nimport { Range, TextEditor } from \"atom\"\n\nexport default class CodeActionAdapter {\n  /** @returns A {Boolean} indicating this adapter can adapt the server based on the given serverCapabilities. */\n  public static canAdapt(serverCapabilities: ServerCapabilities): boolean {\n    return serverCapabilities.codeActionProvider === true\n  }\n\n  /**\n   * Public: Retrieves code actions for a given editor, range, and context (diagnostics). Throws an error if\n   * codeActionProvider is not a registered capability.\n   *\n   * @param connection A {LanguageClientConnection} to the language server that provides highlights.\n   * @param serverCapabilities The {ServerCapabilities} of the language server that will be used.\n   * @param editor The Atom {TextEditor} containing the diagnostics.\n   * @param range The Atom {Range} to fetch code actions for.\n   * @param linterMessages An {Array<linter$Message>} to fetch code actions for. This is typically a list of messages\n   *   intersecting `range`.\n   * @returns A {Promise} of an {Array} of {atomIde$CodeAction}s to display.\n   */\n  public static async getCodeActions(\n    connection: LanguageClientConnection,\n    serverCapabilities: ServerCapabilities,\n    linterAdapter: LinterPushV2Adapter | IdeDiagnosticAdapter | undefined,\n    editor: TextEditor,\n    range: Range,\n    linterMessages: linter.Message[] | atomIde.Diagnostic[],\n    filterActions: (actions: (Command | CodeAction)[] | null) => (Command | CodeAction)[] | null = (actions) => actions,\n    onApply: (action: Command | CodeAction) => Promise<boolean> = () => Promise.resolve(true)\n  ): Promise<atomIde.CodeAction[]> {\n    if (linterAdapter == null) {\n      return []\n    }\n    assert(serverCapabilities.codeActionProvider, \"Must have the textDocument/codeAction capability\")\n\n    const params = createCodeActionParams(linterAdapter, editor, range, linterMessages)\n    const actions = filterActions(await connection.codeAction(params))\n    if (actions === null) {\n      return []\n    }\n    return actions.map((action) => CodeActionAdapter.createCodeAction(action, connection, onApply))\n  }\n\n  private static createCodeAction(\n    action: Command | CodeAction,\n    connection: LanguageClientConnection,\n    onApply: (action: Command | CodeAction) => Promise<boolean>\n  ): atomIde.CodeAction {\n    return {\n      async apply() {\n        if (!(await onApply(action))) {\n          return\n        }\n        if (CodeAction.is(action)) {\n          CodeActionAdapter.applyWorkspaceEdit(action.edit)\n          await CodeActionAdapter.executeCommand(action.command, connection)\n        } else {\n          await CodeActionAdapter.executeCommand(action, connection)\n        }\n      },\n      getTitle(): Promise<string> {\n        return Promise.resolve(action.title)\n      },\n      dispose(): void {},\n    }\n  }\n\n  private static applyWorkspaceEdit(edit: WorkspaceEdit | undefined): void {\n    if (WorkspaceEdit.is(edit)) {\n      ApplyEditAdapter.onApplyEdit({ edit })\n    }\n  }\n\n  private static async executeCommand(command: any, connection: LanguageClientConnection): Promise<void> {\n    if (Command.is(command)) {\n      await connection.executeCommand({\n        command: command.command,\n        arguments: command.arguments,\n      })\n    }\n  }\n}\n\nfunction createCodeActionParams(\n  linterAdapter: LinterPushV2Adapter | IdeDiagnosticAdapter,\n  editor: TextEditor,\n  range: Range,\n  linterMessages: linter.Message[] | atomIde.Diagnostic[]\n): CodeActionParams {\n  let diagnostics: Diagnostic[]\n  if (linterMessages.length === 0) {\n    diagnostics = []\n  } else {\n    // TODO compile time dispatch using function names\n    diagnostics = areLinterMessages(linterMessages)\n      ? linterAdapter.getLSDiagnosticsForMessages(linterMessages as linter.Message[])\n      : (linterAdapter as IdeDiagnosticAdapter).getLSDiagnosticsForIdeDiagnostics(\n          linterMessages as atomIde.Diagnostic[],\n          editor\n        )\n  }\n  return {\n    textDocument: Convert.editorToTextDocumentIdentifier(editor),\n    range: Convert.atomRangeToLSRange(range),\n    context: {\n      diagnostics,\n    },\n  }\n}\n\nfunction areLinterMessages(linterMessages: linter.Message[] | atomIde.Diagnostic[]): boolean {\n  if (\"excerpt\" in linterMessages[0]) {\n    return true\n  }\n  return false\n}\n"]} |
\ | No newline at end of file |