annotate clang-tools-extra/clangd/Diagnostics.h @ 221:79ff65ed7e25

LLVM12 Original
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 15 Jun 2021 19:15:29 +0900
parents 0572611fdcc8
children 5f17cb93ff66
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===--- Diagnostics.h -------------------------------------------*- C++-*-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_DIAGNOSTICS_H
anatofuz
parents:
diff changeset
10 #define LLVM_CLANG_TOOLS_EXTRA_CLANGD_DIAGNOSTICS_H
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 #include "Protocol.h"
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
13 #include "support/Path.h"
150
anatofuz
parents:
diff changeset
14 #include "clang/Basic/Diagnostic.h"
anatofuz
parents:
diff changeset
15 #include "clang/Basic/LangOptions.h"
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
16 #include "clang/Basic/SourceLocation.h"
150
anatofuz
parents:
diff changeset
17 #include "llvm/ADT/ArrayRef.h"
anatofuz
parents:
diff changeset
18 #include "llvm/ADT/DenseSet.h"
anatofuz
parents:
diff changeset
19 #include "llvm/ADT/None.h"
anatofuz
parents:
diff changeset
20 #include "llvm/ADT/Optional.h"
anatofuz
parents:
diff changeset
21 #include "llvm/ADT/STLExtras.h"
anatofuz
parents:
diff changeset
22 #include "llvm/ADT/StringSet.h"
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
23 #include "llvm/Support/JSON.h"
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
24 #include "llvm/Support/SourceMgr.h"
150
anatofuz
parents:
diff changeset
25 #include <cassert>
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
26 #include <functional>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
27 #include <memory>
150
anatofuz
parents:
diff changeset
28 #include <string>
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
29 #include <utility>
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
30 #include <vector>
150
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 namespace clang {
anatofuz
parents:
diff changeset
33 namespace tidy {
anatofuz
parents:
diff changeset
34 class ClangTidyContext;
anatofuz
parents:
diff changeset
35 } // namespace tidy
anatofuz
parents:
diff changeset
36 namespace clangd {
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 struct ClangdDiagnosticOptions {
anatofuz
parents:
diff changeset
39 /// If true, Clangd uses an LSP extension to embed the fixes with the
anatofuz
parents:
diff changeset
40 /// diagnostics that are sent to the client.
anatofuz
parents:
diff changeset
41 bool EmbedFixesInDiagnostics = false;
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 /// If true, Clangd uses the relatedInformation field to include other
anatofuz
parents:
diff changeset
44 /// locations (in particular attached notes).
anatofuz
parents:
diff changeset
45 /// Otherwise, these are flattened into the diagnostic message.
anatofuz
parents:
diff changeset
46 bool EmitRelatedLocations = false;
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 /// If true, Clangd uses an LSP extension to send the diagnostic's
anatofuz
parents:
diff changeset
49 /// category to the client. The category typically describes the compilation
anatofuz
parents:
diff changeset
50 /// stage during which the issue was produced, e.g. "Semantic Issue" or "Parse
anatofuz
parents:
diff changeset
51 /// Issue".
anatofuz
parents:
diff changeset
52 bool SendDiagnosticCategory = false;
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 /// If true, Clangd will add a number of available fixes to the diagnostic's
anatofuz
parents:
diff changeset
55 /// message.
anatofuz
parents:
diff changeset
56 bool DisplayFixesCount = true;
anatofuz
parents:
diff changeset
57 };
anatofuz
parents:
diff changeset
58
anatofuz
parents:
diff changeset
59 /// Contains basic information about a diagnostic.
anatofuz
parents:
diff changeset
60 struct DiagBase {
anatofuz
parents:
diff changeset
61 std::string Message;
anatofuz
parents:
diff changeset
62 // Intended to be used only in error messages.
anatofuz
parents:
diff changeset
63 // May be relative, absolute or even artificially constructed.
anatofuz
parents:
diff changeset
64 std::string File;
anatofuz
parents:
diff changeset
65 // Absolute path to containing file, if available.
anatofuz
parents:
diff changeset
66 llvm::Optional<std::string> AbsFile;
anatofuz
parents:
diff changeset
67
anatofuz
parents:
diff changeset
68 clangd::Range Range;
anatofuz
parents:
diff changeset
69 DiagnosticsEngine::Level Severity = DiagnosticsEngine::Note;
anatofuz
parents:
diff changeset
70 std::string Category;
anatofuz
parents:
diff changeset
71 // Since File is only descriptive, we store a separate flag to distinguish
anatofuz
parents:
diff changeset
72 // diags from the main file.
anatofuz
parents:
diff changeset
73 bool InsideMainFile = false;
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
74 unsigned ID; // e.g. member of clang::diag, or clang-tidy assigned ID.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
75 // Feature modules can make use of this field to propagate data from a
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
76 // diagnostic to a CodeAction request. Each module should only append to the
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
77 // list.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
78 llvm::json::Object OpaqueData;
150
anatofuz
parents:
diff changeset
79 };
anatofuz
parents:
diff changeset
80 llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, const DiagBase &D);
anatofuz
parents:
diff changeset
81
anatofuz
parents:
diff changeset
82 /// Represents a single fix-it that editor can apply to fix the error.
anatofuz
parents:
diff changeset
83 struct Fix {
anatofuz
parents:
diff changeset
84 /// Message for the fix-it.
anatofuz
parents:
diff changeset
85 std::string Message;
anatofuz
parents:
diff changeset
86 /// TextEdits from clang's fix-its. Must be non-empty.
anatofuz
parents:
diff changeset
87 llvm::SmallVector<TextEdit, 1> Edits;
anatofuz
parents:
diff changeset
88 };
anatofuz
parents:
diff changeset
89 llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, const Fix &F);
anatofuz
parents:
diff changeset
90
anatofuz
parents:
diff changeset
91 /// Represents a note for the diagnostic. Severity of notes can only be 'note'
anatofuz
parents:
diff changeset
92 /// or 'remark'.
anatofuz
parents:
diff changeset
93 struct Note : DiagBase {};
anatofuz
parents:
diff changeset
94
anatofuz
parents:
diff changeset
95 /// A top-level diagnostic that may have Notes and Fixes.
anatofuz
parents:
diff changeset
96 struct Diag : DiagBase {
anatofuz
parents:
diff changeset
97 std::string Name; // if ID was recognized.
anatofuz
parents:
diff changeset
98 // The source of this diagnostic.
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
99 enum DiagSource {
150
anatofuz
parents:
diff changeset
100 Unknown,
anatofuz
parents:
diff changeset
101 Clang,
anatofuz
parents:
diff changeset
102 ClangTidy,
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
103 ClangdConfig,
150
anatofuz
parents:
diff changeset
104 } Source = Unknown;
anatofuz
parents:
diff changeset
105 /// Elaborate on the problem, usually pointing to a related piece of code.
anatofuz
parents:
diff changeset
106 std::vector<Note> Notes;
anatofuz
parents:
diff changeset
107 /// *Alternative* fixes for this diagnostic, one should be chosen.
anatofuz
parents:
diff changeset
108 std::vector<Fix> Fixes;
anatofuz
parents:
diff changeset
109 };
anatofuz
parents:
diff changeset
110 llvm::raw_ostream &operator<<(llvm::raw_ostream &OS, const Diag &D);
anatofuz
parents:
diff changeset
111
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
112 Diag toDiag(const llvm::SMDiagnostic &, Diag::DiagSource Source);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
113
150
anatofuz
parents:
diff changeset
114 /// Conversion to LSP diagnostics. Formats the error message of each diagnostic
anatofuz
parents:
diff changeset
115 /// to include all its notes. Notes inside main file are also provided as
anatofuz
parents:
diff changeset
116 /// separate diagnostics with their corresponding fixits. Notes outside main
anatofuz
parents:
diff changeset
117 /// file do not have a corresponding LSP diagnostic, but can still be included
anatofuz
parents:
diff changeset
118 /// as part of their main diagnostic's message.
anatofuz
parents:
diff changeset
119 void toLSPDiags(
anatofuz
parents:
diff changeset
120 const Diag &D, const URIForFile &File, const ClangdDiagnosticOptions &Opts,
anatofuz
parents:
diff changeset
121 llvm::function_ref<void(clangd::Diagnostic, llvm::ArrayRef<Fix>)> OutFn);
anatofuz
parents:
diff changeset
122
anatofuz
parents:
diff changeset
123 /// Convert from Fix to LSP CodeAction.
anatofuz
parents:
diff changeset
124 CodeAction toCodeAction(const Fix &D, const URIForFile &File);
anatofuz
parents:
diff changeset
125
anatofuz
parents:
diff changeset
126 /// Convert from clang diagnostic level to LSP severity.
anatofuz
parents:
diff changeset
127 int getSeverity(DiagnosticsEngine::Level L);
anatofuz
parents:
diff changeset
128
anatofuz
parents:
diff changeset
129 /// StoreDiags collects the diagnostics that can later be reported by
anatofuz
parents:
diff changeset
130 /// clangd. It groups all notes for a diagnostic into a single Diag
anatofuz
parents:
diff changeset
131 /// and filters out diagnostics that don't mention the main file (i.e. neither
anatofuz
parents:
diff changeset
132 /// the diag itself nor its notes are in the main file).
anatofuz
parents:
diff changeset
133 class StoreDiags : public DiagnosticConsumer {
anatofuz
parents:
diff changeset
134 public:
anatofuz
parents:
diff changeset
135 // The ClangTidyContext populates Source and Name for clang-tidy diagnostics.
anatofuz
parents:
diff changeset
136 std::vector<Diag> take(const clang::tidy::ClangTidyContext *Tidy = nullptr);
anatofuz
parents:
diff changeset
137
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
138 void BeginSourceFile(const LangOptions &Opts,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
139 const Preprocessor *PP) override;
150
anatofuz
parents:
diff changeset
140 void EndSourceFile() override;
anatofuz
parents:
diff changeset
141 void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel,
anatofuz
parents:
diff changeset
142 const clang::Diagnostic &Info) override;
anatofuz
parents:
diff changeset
143
anatofuz
parents:
diff changeset
144 using DiagFixer = std::function<std::vector<Fix>(DiagnosticsEngine::Level,
anatofuz
parents:
diff changeset
145 const clang::Diagnostic &)>;
anatofuz
parents:
diff changeset
146 using LevelAdjuster = std::function<DiagnosticsEngine::Level(
anatofuz
parents:
diff changeset
147 DiagnosticsEngine::Level, const clang::Diagnostic &)>;
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
148 using DiagCallback =
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
149 std::function<void(const clang::Diagnostic &, clangd::Diag &)>;
150
anatofuz
parents:
diff changeset
150 /// If set, possibly adds fixes for diagnostics using \p Fixer.
anatofuz
parents:
diff changeset
151 void contributeFixes(DiagFixer Fixer) { this->Fixer = Fixer; }
anatofuz
parents:
diff changeset
152 /// If set, this allows the client of this class to adjust the level of
anatofuz
parents:
diff changeset
153 /// diagnostics, such as promoting warnings to errors, or ignoring
anatofuz
parents:
diff changeset
154 /// diagnostics.
anatofuz
parents:
diff changeset
155 void setLevelAdjuster(LevelAdjuster Adjuster) { this->Adjuster = Adjuster; }
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
156 /// Invokes a callback every time a diagnostics is completely formed. Handler
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
157 /// of the callback can also mutate the diagnostic.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
158 void setDiagCallback(DiagCallback CB) { DiagCB = std::move(CB); }
150
anatofuz
parents:
diff changeset
159
anatofuz
parents:
diff changeset
160 private:
anatofuz
parents:
diff changeset
161 void flushLastDiag();
anatofuz
parents:
diff changeset
162
anatofuz
parents:
diff changeset
163 DiagFixer Fixer = nullptr;
anatofuz
parents:
diff changeset
164 LevelAdjuster Adjuster = nullptr;
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
165 DiagCallback DiagCB = nullptr;
150
anatofuz
parents:
diff changeset
166 std::vector<Diag> Output;
anatofuz
parents:
diff changeset
167 llvm::Optional<LangOptions> LangOpts;
anatofuz
parents:
diff changeset
168 llvm::Optional<Diag> LastDiag;
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
169 llvm::Optional<FullSourceLoc> LastDiagLoc; // Valid only when LastDiag is set.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
170 bool LastDiagOriginallyError = false; // Valid only when LastDiag is set.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
171 SourceManager *OrigSrcMgr = nullptr;
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
172
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
173 llvm::DenseSet<std::pair<unsigned, unsigned>> IncludedErrorLocations;
150
anatofuz
parents:
diff changeset
174 bool LastPrimaryDiagnosticWasSuppressed = false;
anatofuz
parents:
diff changeset
175 };
anatofuz
parents:
diff changeset
176
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
177 /// Determine whether a (non-clang-tidy) diagnostic is suppressed by config.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
178 bool isBuiltinDiagnosticSuppressed(unsigned ID,
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
179 const llvm::StringSet<> &Suppressed);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
180 /// Take a user-specified diagnostic code, and convert it to a normalized form
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
181 /// stored in the config and consumed by isBuiltinDiagnosticsSuppressed.
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
182 ///
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
183 /// (This strips err_ and -W prefix so we can match with or without them.)
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
184 llvm::StringRef normalizeSuppressedCode(llvm::StringRef);
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
185
150
anatofuz
parents:
diff changeset
186 } // namespace clangd
anatofuz
parents:
diff changeset
187 } // namespace clang
anatofuz
parents:
diff changeset
188
anatofuz
parents:
diff changeset
189 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANGD_DIAGNOSTICS_H