UNPKG

23.1 kBJavaScriptView Raw
1"use strict";
2var __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};
11Object.defineProperty(exports, "__esModule", { value: true });
12const convert_1 = require("../convert");
13/** Public: Adapts the language server protocol "textDocument/completion" to the Atom IDE UI Code-format package. */
14class CodeFormatAdapter {
15 /**
16 * Public: Determine whether this adapter can be used to adapt a language server based on the serverCapabilities
17 * matrix containing either a documentFormattingProvider or a documentRangeFormattingProvider.
18 *
19 * @param serverCapabilities The {ServerCapabilities} of the language server to consider.
20 * @returns A {Boolean} indicating this adapter can adapt the server based on the given serverCapabilities.
21 */
22 static canAdapt(serverCapabilities) {
23 return (serverCapabilities.documentRangeFormattingProvider === true ||
24 serverCapabilities.documentFormattingProvider === true);
25 }
26 /**
27 * Public: Format text in the editor using the given language server connection and an optional range. If the server
28 * does not support range formatting then range will be ignored and the entire document formatted.
29 *
30 * @param connection A {LanguageClientConnection} to the language server that will format the text.
31 * @param serverCapabilities The {ServerCapabilities} of the language server that will be used.
32 * @param editor The Atom {TextEditor} containing the text that will be formatted.
33 * @param range The optional Atom {Range} containing the subset of the text to be formatted.
34 * @returns A {Promise} of an {Array} of {Object}s containing the AutoComplete+ suggestions to display.
35 */
36 static format(connection, serverCapabilities, editor, range) {
37 if (serverCapabilities.documentRangeFormattingProvider) {
38 return CodeFormatAdapter.formatRange(connection, editor, range);
39 }
40 if (serverCapabilities.documentFormattingProvider) {
41 return CodeFormatAdapter.formatDocument(connection, editor);
42 }
43 throw new Error("Can not format document, language server does not support it");
44 }
45 /**
46 * Public: Format the entire document of an Atom {TextEditor} by using a given language server.
47 *
48 * @param connection A {LanguageClientConnection} to the language server that will format the text.
49 * @param editor The Atom {TextEditor} containing the document to be formatted.
50 * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.
51 */
52 static formatDocument(connection, editor) {
53 return __awaiter(this, void 0, void 0, function* () {
54 const edits = yield connection.documentFormatting(CodeFormatAdapter.createDocumentFormattingParams(editor));
55 return convert_1.default.convertLsTextEdits(edits);
56 });
57 }
58 /**
59 * Public: Create {DocumentFormattingParams} to be sent to the language server when requesting an entire document is formatted.
60 *
61 * @param editor The Atom {TextEditor} containing the document to be formatted.
62 * @returns A {DocumentFormattingParams} containing the identity of the text document as well as options to be used in
63 * formatting the document such as tab size and tabs vs spaces.
64 */
65 static createDocumentFormattingParams(editor) {
66 return {
67 textDocument: convert_1.default.editorToTextDocumentIdentifier(editor),
68 options: CodeFormatAdapter.getFormatOptions(editor),
69 };
70 }
71 /**
72 * Public: Format a range within an Atom {TextEditor} by using a given language server.
73 *
74 * @param connection A {LanguageClientConnection} to the language server that will format the text.
75 * @param range The Atom {Range} containing the range of text that should be formatted.
76 * @param editor The Atom {TextEditor} containing the document to be formatted.
77 * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.
78 */
79 static formatRange(connection, editor, range) {
80 return __awaiter(this, void 0, void 0, function* () {
81 const edits = yield connection.documentRangeFormatting(CodeFormatAdapter.createDocumentRangeFormattingParams(editor, range));
82 return convert_1.default.convertLsTextEdits(edits);
83 });
84 }
85 /**
86 * Public: Create {DocumentRangeFormattingParams} to be sent to the language server when requesting an entire document
87 * is formatted.
88 *
89 * @param editor The Atom {TextEditor} containing the document to be formatted.
90 * @param range The Atom {Range} containing the range of text that should be formatted.
91 * @returns A {DocumentRangeFormattingParams} containing the identity of the text document, the range of the text to
92 * be formatted as well as the options to be used in formatting the document such as tab size and tabs vs spaces.
93 */
94 static createDocumentRangeFormattingParams(editor, range) {
95 return {
96 textDocument: convert_1.default.editorToTextDocumentIdentifier(editor),
97 range: convert_1.default.atomRangeToLSRange(range),
98 options: CodeFormatAdapter.getFormatOptions(editor),
99 };
100 }
101 /**
102 * Public: Format on type within an Atom {TextEditor} by using a given language server.
103 *
104 * @param connection A {LanguageClientConnection} to the language server that will format the text.
105 * @param editor The Atom {TextEditor} containing the document to be formatted.
106 * @param point The {Point} at which the document to be formatted.
107 * @param character A character that triggered formatting request.
108 * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.
109 */
110 static formatOnType(connection, editor, point, character) {
111 return __awaiter(this, void 0, void 0, function* () {
112 const edits = yield connection.documentOnTypeFormatting(CodeFormatAdapter.createDocumentOnTypeFormattingParams(editor, point, character));
113 return convert_1.default.convertLsTextEdits(edits);
114 });
115 }
116 /**
117 * Public: Create {DocumentOnTypeFormattingParams} to be sent to the language server when requesting an entire
118 * document is formatted.
119 *
120 * @param editor The Atom {TextEditor} containing the document to be formatted.
121 * @param point The {Point} at which the document to be formatted.
122 * @param character A character that triggered formatting request.
123 * @returns A {DocumentOnTypeFormattingParams} containing the identity of the text document, the position of the text
124 * to be formatted, the character that triggered formatting request as well as the options to be used in formatting
125 * the document such as tab size and tabs vs spaces.
126 */
127 static createDocumentOnTypeFormattingParams(editor, point, character) {
128 return {
129 textDocument: convert_1.default.editorToTextDocumentIdentifier(editor),
130 position: convert_1.default.pointToPosition(point),
131 ch: character,
132 options: CodeFormatAdapter.getFormatOptions(editor),
133 };
134 }
135 /**
136 * Public: Create {DocumentRangeFormattingParams} to be sent to the language server when requesting an entire document
137 * is formatted.
138 *
139 * @param editor The Atom {TextEditor} containing the document to be formatted.
140 * @param range The Atom {Range} containing the range of document that should be formatted.
141 * @returns The {FormattingOptions} to be used containing the keys:
142 *
143 * - `tabSize` The number of spaces a tab represents.
144 * - `insertSpaces` {True} if spaces should be used, {False} for tab characters.
145 */
146 static getFormatOptions(editor) {
147 return {
148 tabSize: editor.getTabLength(),
149 insertSpaces: editor.getSoftTabs(),
150 };
151 }
152}
153exports.default = CodeFormatAdapter;
154//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-format-adapter.js","sourceRoot":"","sources":["../../../lib/adapters/code-format-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as atomIde from \"atom-ide-base\"\nimport Convert from \"../convert\"\nimport {\n  LanguageClientConnection,\n  DocumentFormattingParams,\n  DocumentRangeFormattingParams,\n  DocumentOnTypeFormattingParams,\n  FormattingOptions,\n  ServerCapabilities,\n} from \"../languageclient\"\nimport { TextEditor, Range, Point } from \"atom\"\n\n/** Public: Adapts the language server protocol \"textDocument/completion\" to the Atom IDE UI Code-format package. */\nexport default class CodeFormatAdapter {\n  /**\n   * Public: Determine whether this adapter can be used to adapt a language server based on the serverCapabilities\n   * matrix containing either a documentFormattingProvider or a documentRangeFormattingProvider.\n   *\n   * @param serverCapabilities The {ServerCapabilities} of the language server to consider.\n   * @returns A {Boolean} indicating this adapter can adapt the server based on the given serverCapabilities.\n   */\n  public static canAdapt(serverCapabilities: ServerCapabilities): boolean {\n    return (\n      serverCapabilities.documentRangeFormattingProvider === true ||\n      serverCapabilities.documentFormattingProvider === true\n    )\n  }\n\n  /**\n   * Public: Format text in the editor using the given language server connection and an optional range. If the server\n   * does not support range formatting then range will be ignored and the entire document formatted.\n   *\n   * @param connection A {LanguageClientConnection} to the language server that will format the text.\n   * @param serverCapabilities The {ServerCapabilities} of the language server that will be used.\n   * @param editor The Atom {TextEditor} containing the text that will be formatted.\n   * @param range The optional Atom {Range} containing the subset of the text to be formatted.\n   * @returns A {Promise} of an {Array} of {Object}s containing the AutoComplete+ suggestions to display.\n   */\n  public static format(\n    connection: LanguageClientConnection,\n    serverCapabilities: ServerCapabilities,\n    editor: TextEditor,\n    range: Range\n  ): Promise<atomIde.TextEdit[]> {\n    if (serverCapabilities.documentRangeFormattingProvider) {\n      return CodeFormatAdapter.formatRange(connection, editor, range)\n    }\n\n    if (serverCapabilities.documentFormattingProvider) {\n      return CodeFormatAdapter.formatDocument(connection, editor)\n    }\n\n    throw new Error(\"Can not format document, language server does not support it\")\n  }\n\n  /**\n   * Public: Format the entire document of an Atom {TextEditor} by using a given language server.\n   *\n   * @param connection A {LanguageClientConnection} to the language server that will format the text.\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.\n   */\n  public static async formatDocument(\n    connection: LanguageClientConnection,\n    editor: TextEditor\n  ): Promise<atomIde.TextEdit[]> {\n    const edits = await connection.documentFormatting(CodeFormatAdapter.createDocumentFormattingParams(editor))\n    return Convert.convertLsTextEdits(edits)\n  }\n\n  /**\n   * Public: Create {DocumentFormattingParams} to be sent to the language server when requesting an entire document is formatted.\n   *\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @returns A {DocumentFormattingParams} containing the identity of the text document as well as options to be used in\n   *   formatting the document such as tab size and tabs vs spaces.\n   */\n  public static createDocumentFormattingParams(editor: TextEditor): DocumentFormattingParams {\n    return {\n      textDocument: Convert.editorToTextDocumentIdentifier(editor),\n      options: CodeFormatAdapter.getFormatOptions(editor),\n    }\n  }\n\n  /**\n   * Public: Format a range within an Atom {TextEditor} by using a given language server.\n   *\n   * @param connection A {LanguageClientConnection} to the language server that will format the text.\n   * @param range The Atom {Range} containing the range of text that should be formatted.\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.\n   */\n  public static async formatRange(\n    connection: LanguageClientConnection,\n    editor: TextEditor,\n    range: Range\n  ): Promise<atomIde.TextEdit[]> {\n    const edits = await connection.documentRangeFormatting(\n      CodeFormatAdapter.createDocumentRangeFormattingParams(editor, range)\n    )\n    return Convert.convertLsTextEdits(edits)\n  }\n\n  /**\n   * Public: Create {DocumentRangeFormattingParams} to be sent to the language server when requesting an entire document\n   * is formatted.\n   *\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @param range The Atom {Range} containing the range of text that should be formatted.\n   * @returns A {DocumentRangeFormattingParams} containing the identity of the text document, the range of the text to\n   *   be formatted as well as the options to be used in formatting the document such as tab size and tabs vs spaces.\n   */\n  public static createDocumentRangeFormattingParams(editor: TextEditor, range: Range): DocumentRangeFormattingParams {\n    return {\n      textDocument: Convert.editorToTextDocumentIdentifier(editor),\n      range: Convert.atomRangeToLSRange(range),\n      options: CodeFormatAdapter.getFormatOptions(editor),\n    }\n  }\n\n  /**\n   * Public: Format on type within an Atom {TextEditor} by using a given language server.\n   *\n   * @param connection A {LanguageClientConnection} to the language server that will format the text.\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @param point The {Point} at which the document to be formatted.\n   * @param character A character that triggered formatting request.\n   * @returns A {Promise} of an {Array} of {TextEdit} objects that can be applied to the Atom TextEditor to format the document.\n   */\n  public static async formatOnType(\n    connection: LanguageClientConnection,\n    editor: TextEditor,\n    point: Point,\n    character: string\n  ): Promise<atomIde.TextEdit[]> {\n    const edits = await connection.documentOnTypeFormatting(\n      CodeFormatAdapter.createDocumentOnTypeFormattingParams(editor, point, character)\n    )\n    return Convert.convertLsTextEdits(edits)\n  }\n\n  /**\n   * Public: Create {DocumentOnTypeFormattingParams} to be sent to the language server when requesting an entire\n   * document is formatted.\n   *\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @param point The {Point} at which the document to be formatted.\n   * @param character A character that triggered formatting request.\n   * @returns A {DocumentOnTypeFormattingParams} containing the identity of the text document, the position of the text\n   *   to be formatted, the character that triggered formatting request as well as the options to be used in formatting\n   *   the document such as tab size and tabs vs spaces.\n   */\n  public static createDocumentOnTypeFormattingParams(\n    editor: TextEditor,\n    point: Point,\n    character: string\n  ): DocumentOnTypeFormattingParams {\n    return {\n      textDocument: Convert.editorToTextDocumentIdentifier(editor),\n      position: Convert.pointToPosition(point),\n      ch: character,\n      options: CodeFormatAdapter.getFormatOptions(editor),\n    }\n  }\n\n  /**\n   * Public: Create {DocumentRangeFormattingParams} to be sent to the language server when requesting an entire document\n   * is formatted.\n   *\n   * @param editor The Atom {TextEditor} containing the document to be formatted.\n   * @param range The Atom {Range} containing the range of document that should be formatted.\n   * @returns The {FormattingOptions} to be used containing the keys:\n   *\n   *   - `tabSize` The number of spaces a tab represents.\n   *   - `insertSpaces` {True} if spaces should be used, {False} for tab characters.\n   */\n  public static getFormatOptions(editor: TextEditor): FormattingOptions {\n    return {\n      tabSize: editor.getTabLength(),\n      insertSpaces: editor.getSoftTabs(),\n    }\n  }\n}\n"]}
\No newline at end of file