UNPKG

14.5 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.diagnosticTypeToLSSeverity = exports.atomIdeDiagnosticToLSDiagnostic = void 0;
4const ls = require("../languageclient");
5const convert_1 = require("../convert");
6const linter_push_v2_adapter_1 = require("./linter-push-v2-adapter");
7/** @deprecated Use Linter V2 service */
8class IdeDiagnosticAdapter extends linter_push_v2_adapter_1.default {
9 constructor() {
10 super(...arguments);
11 this._diagnosticCodes = new Map();
12 }
13 /**
14 * Public: Capture the diagnostics sent from a langguage server, convert them to the Linter V2 format and forward them
15 * on to any attached {V2IndieDelegate}s.
16 *
17 * @deprecated Use Linter V2 service
18 * @param params The {PublishDiagnosticsParams} received from the language server that should be captured and
19 * forwarded on to any attached {V2IndieDelegate}s.
20 */
21 captureDiagnostics(params) {
22 const path = convert_1.default.uriToPath(params.uri);
23 const codeMap = new Map();
24 const messages = params.diagnostics.map((d) => {
25 const linterMessage = this.diagnosticToV2Message(path, d);
26 codeMap.set(getCodeKey(linterMessage.location.position, d.message), d.code);
27 return linterMessage;
28 });
29 this._diagnosticMap.set(path, messages);
30 this._diagnosticCodes.set(path, codeMap);
31 this._indies.forEach((i) => i.setMessages(path, messages));
32 }
33 /**
34 * Public: get diagnostics for the given linter messages
35 *
36 * @deprecated Use Linter V2 service
37 * @param linterMessages An array of linter {V2Message}
38 * @param editor
39 * @returns An array of LS {Diagnostic[]}
40 */
41 getLSDiagnosticsForIdeDiagnostics(diagnostics, editor) {
42 return diagnostics.map((diagnostic) => this.getLSDiagnosticForIdeDiagnostic(diagnostic, editor));
43 }
44 /**
45 * Public: Get the {Diagnostic} that is associated with the given {atomIde.Diagnostic}.
46 *
47 * @deprecated Use Linter V2 service
48 * @param diagnostic The {atomIde.Diagnostic} object to fetch the {Diagnostic} for.
49 * @param editor
50 * @returns The associated {Diagnostic}.
51 */
52 getLSDiagnosticForIdeDiagnostic(diagnostic, editor) {
53 // Retrieve the stored diagnostic code if it exists.
54 // Until the Linter API provides a place to store the code,
55 // there's no real way for the code actions API to give it back to us.
56 const converted = atomIdeDiagnosticToLSDiagnostic(diagnostic);
57 if (diagnostic.range != null && diagnostic.text != null) {
58 const code = this.getDiagnosticCode(editor, diagnostic.range, diagnostic.text);
59 if (code != null) {
60 converted.code = code;
61 }
62 }
63 return converted;
64 }
65 /**
66 * Private: Get the recorded diagnostic code for a range/message. Diagnostic codes are tricky because there's no
67 * suitable place in the Linter API for them. For now, we'll record the original code for each range/message
68 * combination and retrieve it when needed (e.g. for passing back into code actions)
69 */
70 getDiagnosticCode(editor, range, text) {
71 const path = editor.getPath();
72 if (path != null) {
73 const diagnosticCodes = this._diagnosticCodes.get(path);
74 if (diagnosticCodes != null) {
75 return diagnosticCodes.get(getCodeKey(range, text)) || null;
76 }
77 }
78 return null;
79 }
80}
81exports.default = IdeDiagnosticAdapter;
82/** @deprecated Use Linter V2 service */
83function atomIdeDiagnosticToLSDiagnostic(diagnostic) {
84 // TODO: support diagnostic codes and codeDescriptions
85 // TODO!: support data
86 return {
87 range: convert_1.default.atomRangeToLSRange(diagnostic.range),
88 severity: diagnosticTypeToLSSeverity(diagnostic.type),
89 source: diagnostic.providerName,
90 message: diagnostic.text || "",
91 };
92}
93exports.atomIdeDiagnosticToLSDiagnostic = atomIdeDiagnosticToLSDiagnostic;
94/** @deprecated Use Linter V2 service */
95function diagnosticTypeToLSSeverity(type) {
96 switch (type) {
97 case "Error":
98 return ls.DiagnosticSeverity.Error;
99 case "Warning":
100 return ls.DiagnosticSeverity.Warning;
101 case "Info":
102 return ls.DiagnosticSeverity.Information;
103 default:
104 throw Error(`Unexpected diagnostic type ${type}`);
105 }
106}
107exports.diagnosticTypeToLSSeverity = diagnosticTypeToLSSeverity;
108function getCodeKey(range, text) {
109 return [].concat(...range.serialize(), text).join(",");
110}
111//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diagnostic-adapter.js","sourceRoot":"","sources":["../../../lib/adapters/diagnostic-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import * as atomIde from \"atom-ide-base\"\nimport * as atom from \"atom\"\nimport * as ls from \"../languageclient\"\nimport Convert from \"../convert\"\nimport LinterPushV2Adapter from \"./linter-push-v2-adapter\"\n\n/** @deprecated Use Linter V2 service */\nexport type DiagnosticCode = number | string\n\n/** @deprecated Use Linter V2 service */\nexport default class IdeDiagnosticAdapter extends LinterPushV2Adapter {\n  private _diagnosticCodes: Map<string, Map<string, DiagnosticCode | null>> = new Map()\n\n  /**\n   * Public: Capture the diagnostics sent from a langguage server, convert them to the Linter V2 format and forward them\n   * on to any attached {V2IndieDelegate}s.\n   *\n   * @deprecated Use Linter V2 service\n   * @param params The {PublishDiagnosticsParams} received from the language server that should be captured and\n   *   forwarded on to any attached {V2IndieDelegate}s.\n   */\n  public captureDiagnostics(params: ls.PublishDiagnosticsParams): void {\n    const path = Convert.uriToPath(params.uri)\n    const codeMap = new Map()\n    const messages = params.diagnostics.map((d) => {\n      const linterMessage = this.diagnosticToV2Message(path, d)\n      codeMap.set(getCodeKey(linterMessage.location.position, d.message), d.code)\n      return linterMessage\n    })\n    this._diagnosticMap.set(path, messages)\n    this._diagnosticCodes.set(path, codeMap)\n    this._indies.forEach((i) => i.setMessages(path, messages))\n  }\n\n  /**\n   * Public: get diagnostics for the given linter messages\n   *\n   * @deprecated Use Linter V2 service\n   * @param linterMessages An array of linter {V2Message}\n   * @param editor\n   * @returns An array of LS {Diagnostic[]}\n   */\n  public getLSDiagnosticsForIdeDiagnostics(\n    diagnostics: atomIde.Diagnostic[],\n    editor: atom.TextEditor\n  ): ls.Diagnostic[] {\n    return diagnostics.map((diagnostic) => this.getLSDiagnosticForIdeDiagnostic(diagnostic, editor))\n  }\n\n  /**\n   * Public: Get the {Diagnostic} that is associated with the given {atomIde.Diagnostic}.\n   *\n   * @deprecated Use Linter V2 service\n   * @param diagnostic The {atomIde.Diagnostic} object to fetch the {Diagnostic} for.\n   * @param editor\n   * @returns The associated {Diagnostic}.\n   */\n  public getLSDiagnosticForIdeDiagnostic(diagnostic: atomIde.Diagnostic, editor: atom.TextEditor): ls.Diagnostic {\n    // Retrieve the stored diagnostic code if it exists.\n    // Until the Linter API provides a place to store the code,\n    // there's no real way for the code actions API to give it back to us.\n    const converted = atomIdeDiagnosticToLSDiagnostic(diagnostic)\n    if (diagnostic.range != null && diagnostic.text != null) {\n      const code = this.getDiagnosticCode(editor, diagnostic.range, diagnostic.text)\n      if (code != null) {\n        converted.code = code\n      }\n    }\n    return converted\n  }\n\n  /**\n   * Private: Get the recorded diagnostic code for a range/message. Diagnostic codes are tricky because there's no\n   * suitable place in the Linter API for them. For now, we'll record the original code for each range/message\n   * combination and retrieve it when needed (e.g. for passing back into code actions)\n   */\n  private getDiagnosticCode(editor: atom.TextEditor, range: atom.Range, text: string): DiagnosticCode | null {\n    const path = editor.getPath()\n    if (path != null) {\n      const diagnosticCodes = this._diagnosticCodes.get(path)\n      if (diagnosticCodes != null) {\n        return diagnosticCodes.get(getCodeKey(range, text)) || null\n      }\n    }\n    return null\n  }\n}\n\n/** @deprecated Use Linter V2 service */\nexport function atomIdeDiagnosticToLSDiagnostic(diagnostic: atomIde.Diagnostic): ls.Diagnostic {\n  // TODO: support diagnostic codes and codeDescriptions\n  // TODO!: support data\n  return {\n    range: Convert.atomRangeToLSRange(diagnostic.range),\n    severity: diagnosticTypeToLSSeverity(diagnostic.type),\n    source: diagnostic.providerName,\n    message: diagnostic.text || \"\",\n  }\n}\n\n/** @deprecated Use Linter V2 service */\nexport function diagnosticTypeToLSSeverity(type: atomIde.DiagnosticType): ls.DiagnosticSeverity {\n  switch (type) {\n    case \"Error\":\n      return ls.DiagnosticSeverity.Error\n    case \"Warning\":\n      return ls.DiagnosticSeverity.Warning\n    case \"Info\":\n      return ls.DiagnosticSeverity.Information\n    default:\n      throw Error(`Unexpected diagnostic type ${type}`)\n  }\n}\n\nfunction getCodeKey(range: atom.Range, text: string): string {\n  return ([] as any[]).concat(...range.serialize(), text).join(\",\")\n}\n"]}
\No newline at end of file