[clangd] Don't use the optional "severity" when comparing Diagnostic.

Summary:
We use Diagnostic as a key to find the corresponding FixIt when we do
the "apply-fix", but the "severity" field could be omitted, in some cases,
the codeAction request sent from LSP clients (e.g. VScode) doesn't include the
`severity` field, which makes clangd fail to find the FixIt.

Test the following code in VScode, before the fix, no FixIt shown.

```
void main() {}
^~~~
```

Reviewers: sammccall

Reviewed By: sammccall

Subscribers: klimek, ilya-biryukov, cfe-commits

Differential Revision: https://reviews.llvm.org/D41280

llvm-svn: 321106
This commit is contained in:
Haojian Wu 2017-12-19 20:52:56 +00:00
parent 5e8cba9e39
commit 7934685c3d
2 changed files with 11 additions and 9 deletions

View File

@ -88,7 +88,8 @@ private:
bool IsDone = false;
std::mutex FixItsMutex;
typedef std::map<clangd::Diagnostic, std::vector<TextEdit>>
typedef std::map<clangd::Diagnostic, std::vector<TextEdit>,
LSPDiagnosticCompare>
DiagnosticToReplacementMap;
/// Caches FixIts per file and diagnostics
llvm::StringMap<DiagnosticToReplacementMap> FixItsMap;

View File

@ -322,14 +322,15 @@ struct Diagnostic {
/// The diagnostic's message.
std::string message;
friend bool operator==(const Diagnostic &LHS, const Diagnostic &RHS) {
return std::tie(LHS.range, LHS.severity, LHS.message) ==
std::tie(RHS.range, RHS.severity, RHS.message);
}
friend bool operator<(const Diagnostic &LHS, const Diagnostic &RHS) {
return std::tie(LHS.range, LHS.severity, LHS.message) <
std::tie(RHS.range, RHS.severity, RHS.message);
};
/// A LSP-specific comparator used to find diagnostic in a container like
/// std:map.
/// We only use the required fields of Diagnostic to do the comparsion to avoid
/// any regression issues from LSP clients (e.g. VScode), see
/// https://git.io/vbr29
struct LSPDiagnosticCompare {
bool operator()(const Diagnostic& LHS, const Diagnostic& RHS) const {
return std::tie(LHS.range, LHS.message) < std::tie(RHS.range, RHS.message);
}
};
bool fromJSON(const json::Expr &, Diagnostic &);