UNPKG

atom-languageclient

Version:
208 lines 26.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const ls = require("./languageclient"); const atom_1 = require("atom"); // eslint-disable-next-line import/no-deprecated const diagnostic_adapter_1 = require("./adapters/diagnostic-adapter"); /** * Public: Class that contains a number of helper methods for general conversions between the language server protocol * and Atom/Atom packages. */ class Convert { /** * Public: Convert a path to a Uri. * * @param filePath A file path to convert to a Uri. * @returns The Uri corresponding to the path. e.g. file:///a/b/c.txt */ static pathToUri(filePath) { if (new URL(filePath, "file://").protocol !== "file:") { return filePath; } let newPath = filePath.replace(/\\/g, "/"); if (newPath[0] !== "/") { newPath = `/${newPath}`; } return encodeURI(`file://${newPath}`).replace(/[#?]/g, encodeURIComponent); } /** * Public: Convert a Uri to a path. * * @param uri A Uri to convert to a file path. * @returns A file path corresponding to the Uri. e.g. /a/b/c.txt If the Uri does not begin file: then it is returned * as-is to allow Atom to deal with http/https sources in the future. */ static uriToPath(uri) { const url = new URL(uri, "file://"); if (url.protocol !== "file:" || url.pathname == null) { return uri; } let filePath = decodeURIComponent(url.pathname); if (process.platform === "win32") { // Deal with Windows drive names if (filePath[0] === "/") { filePath = filePath.substr(1); } return filePath.replace(/\//g, "\\"); } return filePath; } /** * Public: Convert an Atom {Point} to a language server {Position}. * * @param point An Atom {Point} to convert from. * @returns The {Position} representation of the Atom {PointObject}. */ static pointToPosition(point) { return { line: point.row, character: point.column }; } /** * Public: Convert a language server {Position} into an Atom {PointObject}. * * @param position A language server {Position} to convert from. * @returns The Atom {PointObject} representation of the given {Position}. */ static positionToPoint(position) { return new atom_1.Point(position.line, position.character); } /** * Public: Convert a language server {Range} into an Atom {Range}. * * @param range A language server {Range} to convert from. * @returns The Atom {Range} representation of the given language server {Range}. */ static lsRangeToAtomRange(range) { return new atom_1.Range(Convert.positionToPoint(range.start), Convert.positionToPoint(range.end)); } /** * Public: Convert an Atom {Range} into an language server {Range}. * * @param range An Atom {Range} to convert from. * @returns The language server {Range} representation of the given Atom {Range}. */ static atomRangeToLSRange(range) { return { start: Convert.pointToPosition(range.start), end: Convert.pointToPosition(range.end), }; } /** * Public: Create a {TextDocumentIdentifier} from an Atom {TextEditor}. * * @param editor A {TextEditor} that will be used to form the uri property. * @returns A {TextDocumentIdentifier} that has a `uri` property with the Uri for the given editor's path. */ static editorToTextDocumentIdentifier(editor) { return { uri: Convert.pathToUri(editor.getPath() || "") }; } /** * Public: Create a {TextDocumentPositionParams} from a {TextEditor} and optional {Point}. * * @param editor A {TextEditor} that will be used to form the uri property. * @param point An optional {Point} that will supply the position property. If not specified the current cursor * position will be used. * @returns A {TextDocumentPositionParams} that has textDocument property with the editors {TextDocumentIdentifier} * and a position property with the supplied point (or current cursor position when not specified). */ static editorToTextDocumentPositionParams(editor, point) { return { textDocument: Convert.editorToTextDocumentIdentifier(editor), position: Convert.pointToPosition(point != null ? point : editor.getCursorBufferPosition()), }; } /** * Public: Create a string of scopes for the atom text editor using the data-grammar selector from an {Array} of * grammarScope strings. * * @param grammarScopes An {Array} of grammar scope string to convert from. * @returns A single comma-separated list of CSS selectors targetting the grammars of Atom text editors. e.g. `['c', * 'cpp']` => `'atom-text-editor[data-grammar='c'], atom-text-editor[data-grammar='cpp']` */ static grammarScopesToTextEditorScopes(grammarScopes) { return grammarScopes .map((g) => `atom-text-editor[data-grammar="${Convert.encodeHTMLAttribute(g.replace(/\./g, " "))}"]`) .join(", "); } /** * Public: Encode a string so that it can be safely used within a HTML attribute - i.e. replacing all quoted values * with their HTML entity encoded versions. e.g. `Hello"` becomes `Hello&quot;` * * @param s A string to be encoded. * @returns A string that is HTML attribute encoded by replacing &, <, >, " and ' with their HTML entity named equivalents. */ static encodeHTMLAttribute(s) { const attributeMap = { "&": "&amp;", "<": "&lt;", ">": "&gt;", '"': "&quot;", "'": "&apos;", }; return s.replace(/["&'<>]/g, (c) => attributeMap[c]); } /** * Public: Convert an Atom File Event as received from atom.project.onDidChangeFiles and convert it into an Array of * Language Server Protocol {FileEvent} objects. Normally this will be a 1-to-1 but renames will be represented by a * deletion and a subsequent creation as LSP does not know about renames. * * @param fileEvent An {atom$ProjectFileEvent} to be converted. * @returns An array of LSP {ls.FileEvent} objects that equivalent conversions to the fileEvent parameter. */ static atomFileEventToLSFileEvents(fileEvent) { switch (fileEvent.action) { case "created": return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Created }]; case "modified": return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Changed }]; case "deleted": return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Deleted }]; case "renamed": { const results = []; if (fileEvent.oldPath) { results.push({ uri: Convert.pathToUri(fileEvent.oldPath), type: ls.FileChangeType.Deleted }); } if (fileEvent.path) { results.push({ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Created }); } return results; } default: return []; } } /** @deprecated Use Linter V2 service */ static atomIdeDiagnosticToLSDiagnostic(diagnostic) { // eslint-disable-next-line import/no-deprecated return diagnostic_adapter_1.atomIdeDiagnosticToLSDiagnostic(diagnostic); } /** @deprecated Use Linter V2 service */ static diagnosticTypeToLSSeverity(type) { // eslint-disable-next-line import/no-deprecated return diagnostic_adapter_1.diagnosticTypeToLSSeverity(type); } /** * Public: Convert an array of language server protocol {atomIde.TextEdit} objects to an equivalent array of Atom * {atomIde.TextEdit} objects. * * @param textEdits The language server protocol {atomIde.TextEdit} objects to convert. * @returns An {Array} of Atom {atomIde.TextEdit} objects. */ static convertLsTextEdits(textEdits) { return (textEdits || []).map(Convert.convertLsTextEdit); } /** * Public: Convert a language server protocol {atomIde.TextEdit} object to the Atom equivalent {atomIde.TextEdit}. * * @param textEdits The language server protocol {atomIde.TextEdit} objects to convert. * @returns An Atom {atomIde.TextEdit} object. */ static convertLsTextEdit(textEdit) { // TODO: support annotations return { oldRange: Convert.lsRangeToAtomRange(textEdit.range), newText: textEdit.newText, }; } } exports.default = Convert; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"convert.js","sourceRoot":"","sources":["../../lib/convert.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as atomIde from \"atom-ide-base\"\nimport * as ls from \"./languageclient\"\nimport { Point, FilesystemChange, Range, TextEditor } from \"atom\"\n\n// eslint-disable-next-line import/no-deprecated\nimport { diagnosticTypeToLSSeverity, atomIdeDiagnosticToLSDiagnostic } from \"./adapters/diagnostic-adapter\"\n\n/**\n * Public: Class that contains a number of helper methods for general conversions between the language server protocol\n * and Atom/Atom packages.\n */\nexport default class Convert {\n  /**\n   * Public: Convert a path to a Uri.\n   *\n   * @param filePath A file path to convert to a Uri.\n   * @returns The Uri corresponding to the path. e.g. file:///a/b/c.txt\n   */\n  public static pathToUri(filePath: string): string {\n    if (new URL(filePath, \"file://\").protocol !== \"file:\") {\n      return filePath\n    }\n    let newPath = filePath.replace(/\\\\/g, \"/\")\n    if (newPath[0] !== \"/\") {\n      newPath = `/${newPath}`\n    }\n    return encodeURI(`file://${newPath}`).replace(/[#?]/g, encodeURIComponent)\n  }\n\n  /**\n   * Public: Convert a Uri to a path.\n   *\n   * @param uri A Uri to convert to a file path.\n   * @returns A file path corresponding to the Uri. e.g. /a/b/c.txt If the Uri does not begin file: then it is returned\n   *   as-is to allow Atom to deal with http/https sources in the future.\n   */\n  public static uriToPath(uri: string): string {\n    const url = new URL(uri, \"file://\")\n    if (url.protocol !== \"file:\" || url.pathname == null) {\n      return uri\n    }\n\n    let filePath = decodeURIComponent(url.pathname)\n    if (process.platform === \"win32\") {\n      // Deal with Windows drive names\n      if (filePath[0] === \"/\") {\n        filePath = filePath.substr(1)\n      }\n      return filePath.replace(/\\//g, \"\\\\\")\n    }\n    return filePath\n  }\n\n  /**\n   * Public: Convert an Atom {Point} to a language server {Position}.\n   *\n   * @param point An Atom {Point} to convert from.\n   * @returns The {Position} representation of the Atom {PointObject}.\n   */\n  public static pointToPosition(point: Point): ls.Position {\n    return { line: point.row, character: point.column }\n  }\n\n  /**\n   * Public: Convert a language server {Position} into an Atom {PointObject}.\n   *\n   * @param position A language server {Position} to convert from.\n   * @returns The Atom {PointObject} representation of the given {Position}.\n   */\n  public static positionToPoint(position: ls.Position): Point {\n    return new Point(position.line, position.character)\n  }\n\n  /**\n   * Public: Convert a language server {Range} into an Atom {Range}.\n   *\n   * @param range A language server {Range} to convert from.\n   * @returns The Atom {Range} representation of the given language server {Range}.\n   */\n  public static lsRangeToAtomRange(range: ls.Range): Range {\n    return new Range(Convert.positionToPoint(range.start), Convert.positionToPoint(range.end))\n  }\n\n  /**\n   * Public: Convert an Atom {Range} into an language server {Range}.\n   *\n   * @param range An Atom {Range} to convert from.\n   * @returns The language server {Range} representation of the given Atom {Range}.\n   */\n  public static atomRangeToLSRange(range: Range): ls.Range {\n    return {\n      start: Convert.pointToPosition(range.start),\n      end: Convert.pointToPosition(range.end),\n    }\n  }\n\n  /**\n   * Public: Create a {TextDocumentIdentifier} from an Atom {TextEditor}.\n   *\n   * @param editor A {TextEditor} that will be used to form the uri property.\n   * @returns A {TextDocumentIdentifier} that has a `uri` property with the Uri for the given editor's path.\n   */\n  public static editorToTextDocumentIdentifier(editor: TextEditor): ls.TextDocumentIdentifier {\n    return { uri: Convert.pathToUri(editor.getPath() || \"\") }\n  }\n\n  /**\n   * Public: Create a {TextDocumentPositionParams} from a {TextEditor} and optional {Point}.\n   *\n   * @param editor A {TextEditor} that will be used to form the uri property.\n   * @param point An optional {Point} that will supply the position property. If not specified the current cursor\n   *   position will be used.\n   * @returns A {TextDocumentPositionParams} that has textDocument property with the editors {TextDocumentIdentifier}\n   *   and a position property with the supplied point (or current cursor position when not specified).\n   */\n  public static editorToTextDocumentPositionParams(editor: TextEditor, point?: Point): ls.TextDocumentPositionParams {\n    return {\n      textDocument: Convert.editorToTextDocumentIdentifier(editor),\n      position: Convert.pointToPosition(point != null ? point : editor.getCursorBufferPosition()),\n    }\n  }\n\n  /**\n   * Public: Create a string of scopes for the atom text editor using the data-grammar selector from an {Array} of\n   * grammarScope strings.\n   *\n   * @param grammarScopes An {Array} of grammar scope string to convert from.\n   * @returns A single comma-separated list of CSS selectors targetting the grammars of Atom text editors. e.g. `['c',\n   *   'cpp']` => `'atom-text-editor[data-grammar='c'], atom-text-editor[data-grammar='cpp']`\n   */\n  public static grammarScopesToTextEditorScopes(grammarScopes: string[]): string {\n    return grammarScopes\n      .map((g) => `atom-text-editor[data-grammar=\"${Convert.encodeHTMLAttribute(g.replace(/\\./g, \" \"))}\"]`)\n      .join(\", \")\n  }\n\n  /**\n   * Public: Encode a string so that it can be safely used within a HTML attribute - i.e. replacing all quoted values\n   * with their HTML entity encoded versions. e.g. `Hello\"` becomes `Hello&quot;`\n   *\n   * @param s A string to be encoded.\n   * @returns A string that is HTML attribute encoded by replacing &, <, >, \" and ' with their HTML entity named equivalents.\n   */\n  public static encodeHTMLAttribute(s: string): string {\n    const attributeMap: { [key: string]: string } = {\n      \"&\": \"&amp;\",\n      \"<\": \"&lt;\",\n      \">\": \"&gt;\",\n      '\"': \"&quot;\",\n      \"'\": \"&apos;\",\n    }\n    return s.replace(/[\"&'<>]/g, (c) => attributeMap[c])\n  }\n\n  /**\n   * Public: Convert an Atom File Event as received from atom.project.onDidChangeFiles and convert it into an Array of\n   * Language Server Protocol {FileEvent} objects. Normally this will be a 1-to-1 but renames will be represented by a\n   * deletion and a subsequent creation as LSP does not know about renames.\n   *\n   * @param fileEvent An {atom$ProjectFileEvent} to be converted.\n   * @returns An array of LSP {ls.FileEvent} objects that equivalent conversions to the fileEvent parameter.\n   */\n  public static atomFileEventToLSFileEvents(fileEvent: FilesystemChange): ls.FileEvent[] {\n    switch (fileEvent.action) {\n      case \"created\":\n        return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Created }]\n      case \"modified\":\n        return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Changed }]\n      case \"deleted\":\n        return [{ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Deleted }]\n      case \"renamed\": {\n        const results: Array<{ uri: string; type: ls.FileChangeType }> = []\n        if (fileEvent.oldPath) {\n          results.push({ uri: Convert.pathToUri(fileEvent.oldPath), type: ls.FileChangeType.Deleted })\n        }\n        if (fileEvent.path) {\n          results.push({ uri: Convert.pathToUri(fileEvent.path), type: ls.FileChangeType.Created })\n        }\n        return results\n      }\n      default:\n        return []\n    }\n  }\n\n  /** @deprecated Use Linter V2 service */\n  public static atomIdeDiagnosticToLSDiagnostic(diagnostic: atomIde.Diagnostic): ls.Diagnostic {\n    // eslint-disable-next-line import/no-deprecated\n    return atomIdeDiagnosticToLSDiagnostic(diagnostic)\n  }\n\n  /** @deprecated Use Linter V2 service */\n  public static diagnosticTypeToLSSeverity(type: atomIde.DiagnosticType): ls.DiagnosticSeverity {\n    // eslint-disable-next-line import/no-deprecated\n    return diagnosticTypeToLSSeverity(type)\n  }\n\n  /**\n   * Public: Convert an array of language server protocol {atomIde.TextEdit} objects to an equivalent array of Atom\n   * {atomIde.TextEdit} objects.\n   *\n   * @param textEdits The language server protocol {atomIde.TextEdit} objects to convert.\n   * @returns An {Array} of Atom {atomIde.TextEdit} objects.\n   */\n  public static convertLsTextEdits(textEdits?: ls.TextEdit[] | null): atomIde.TextEdit[] {\n    return (textEdits || []).map(Convert.convertLsTextEdit)\n  }\n\n  /**\n   * Public: Convert a language server protocol {atomIde.TextEdit} object to the Atom equivalent {atomIde.TextEdit}.\n   *\n   * @param textEdits The language server protocol {atomIde.TextEdit} objects to convert.\n   * @returns An Atom {atomIde.TextEdit} object.\n   */\n  public static convertLsTextEdit(textEdit: ls.TextEdit): atomIde.TextEdit {\n    // TODO: support annotations\n    return {\n      oldRange: Convert.lsRangeToAtomRange(textEdit.range),\n      newText: textEdit.newText,\n    }\n  }\n}\n"]}