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 convert_1 = require("../convert");
|
13 | /** Public: Adapts the language server protocol "textDocument/completion" to the Atom IDE UI Code-format package. */
|
14 | class 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 | }
|
153 | exports.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":";;;;;;;;;;;AACA,wCAAgC;AAWhC,oHAAoH;AACpH,MAAqB,iBAAiB;IACpC;;;;;;OAMG;IACI,MAAM,CAAC,QAAQ,CAAC,kBAAsC;QAC3D,OAAO,CACL,kBAAkB,CAAC,+BAA+B,KAAK,IAAI;YAC3D,kBAAkB,CAAC,0BAA0B,KAAK,IAAI,CACvD,CAAA;IACH,CAAC;IAED;;;;;;;;;OASG;IACI,MAAM,CAAC,MAAM,CAClB,UAAoC,EACpC,kBAAsC,EACtC,MAAkB,EAClB,KAAY;QAEZ,IAAI,kBAAkB,CAAC,+BAA+B,EAAE;YACtD,OAAO,iBAAiB,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAA;SAChE;QAED,IAAI,kBAAkB,CAAC,0BAA0B,EAAE;YACjD,OAAO,iBAAiB,CAAC,cAAc,CAAC,UAAU,EAAE,MAAM,CAAC,CAAA;SAC5D;QAED,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAA;IACjF,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAO,cAAc,CAChC,UAAoC,EACpC,MAAkB;;YAElB,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC,CAAA;YAC3G,OAAO,iBAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QAC1C,CAAC;KAAA;IAED;;;;;;OAMG;IACI,MAAM,CAAC,8BAA8B,CAAC,MAAkB;QAC7D,OAAO;YACL,YAAY,EAAE,iBAAO,CAAC,8BAA8B,CAAC,MAAM,CAAC;YAC5D,OAAO,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,MAAM,CAAC;SACpD,CAAA;IACH,CAAC;IAED;;;;;;;OAOG;IACI,MAAM,CAAO,WAAW,CAC7B,UAAoC,EACpC,MAAkB,EAClB,KAAY;;YAEZ,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,uBAAuB,CACpD,iBAAiB,CAAC,mCAAmC,CAAC,MAAM,EAAE,KAAK,CAAC,CACrE,CAAA;YACD,OAAO,iBAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QAC1C,CAAC;KAAA;IAED;;;;;;;;OAQG;IACI,MAAM,CAAC,mCAAmC,CAAC,MAAkB,EAAE,KAAY;QAChF,OAAO;YACL,YAAY,EAAE,iBAAO,CAAC,8BAA8B,CAAC,MAAM,CAAC;YAC5D,KAAK,EAAE,iBAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC;YACxC,OAAO,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,MAAM,CAAC;SACpD,CAAA;IACH,CAAC;IAED;;;;;;;;OAQG;IACI,MAAM,CAAO,YAAY,CAC9B,UAAoC,EACpC,MAAkB,EAClB,KAAY,EACZ,SAAiB;;YAEjB,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,wBAAwB,CACrD,iBAAiB,CAAC,oCAAoC,CAAC,MAAM,EAAE,KAAK,EAAE,SAAS,CAAC,CACjF,CAAA;YACD,OAAO,iBAAO,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QAC1C,CAAC;KAAA;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,oCAAoC,CAChD,MAAkB,EAClB,KAAY,EACZ,SAAiB;QAEjB,OAAO;YACL,YAAY,EAAE,iBAAO,CAAC,8BAA8B,CAAC,MAAM,CAAC;YAC5D,QAAQ,EAAE,iBAAO,CAAC,eAAe,CAAC,KAAK,CAAC;YACxC,EAAE,EAAE,SAAS;YACb,OAAO,EAAE,iBAAiB,CAAC,gBAAgB,CAAC,MAAM,CAAC;SACpD,CAAA;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,gBAAgB,CAAC,MAAkB;QAC/C,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,YAAY,EAAE;YAC9B,YAAY,EAAE,MAAM,CAAC,WAAW,EAAE;SACnC,CAAA;IACH,CAAC;CACF;AAzKD,oCAyKC","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 |