1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | exports.diagnosticTypeToLSSeverity = exports.atomIdeDiagnosticToLSDiagnostic = void 0;
|
4 | const ls = require("../languageclient");
|
5 | const convert_1 = require("../convert");
|
6 | const linter_push_v2_adapter_1 = require("./linter-push-v2-adapter");
|
7 | /** @deprecated Use Linter V2 service */
|
8 | class 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 | }
|
81 | exports.default = IdeDiagnosticAdapter;
|
82 | /** @deprecated Use Linter V2 service */
|
83 | function 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 | }
|
93 | exports.atomIdeDiagnosticToLSDiagnostic = atomIdeDiagnosticToLSDiagnostic;
|
94 | /** @deprecated Use Linter V2 service */
|
95 | function 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 | }
|
107 | exports.diagnosticTypeToLSSeverity = diagnosticTypeToLSSeverity;
|
108 | function 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 |