2017-05-16 17:38:59 +08:00
|
|
|
//===--- ClangdLSPServer.h - LSP server --------------------------*- C++-*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2017-05-16 17:38:59 +08:00
|
|
|
//
|
2018-08-15 00:03:32 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2017-05-16 17:38:59 +08:00
|
|
|
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_CLANGDLSPSERVER_H
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANGD_CLANGDLSPSERVER_H
|
|
|
|
|
|
|
|
#include "ClangdServer.h"
|
2018-03-16 22:30:42 +08:00
|
|
|
#include "DraftStore.h"
|
[clangd] Implementation of workspace/symbol request
Summary:
This is a basic implementation of the "workspace/symbol" request which is
used to find symbols by a string query. Since this is similar to code completion
in terms of result, this implementation reuses the "fuzzyFind" in order to get
matches. For now, the scoring algorithm is the same as code completion and
improvements could be done in the future.
The index model doesn't contain quite enough symbols for this to cover
common symbols like methods, enum class enumerators, functions in unamed
namespaces, etc. The index model will be augmented separately to achieve this.
Reviewers: sammccall, ilya-biryukov
Reviewed By: sammccall
Subscribers: jkorous, hokein, simark, sammccall, klimek, mgorny, ilya-biryukov, mgrang, jkorous-apple, ioeric, MaskRay, cfe-commits
Differential Revision: https://reviews.llvm.org/D44882
llvm-svn: 330637
2018-04-24 04:00:52 +08:00
|
|
|
#include "FindSymbols.h"
|
2017-06-13 23:59:43 +08:00
|
|
|
#include "GlobalCompilationDatabase.h"
|
2021-02-12 05:47:58 +08:00
|
|
|
#include "LSPBinder.h"
|
2017-05-16 17:38:59 +08:00
|
|
|
#include "Protocol.h"
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
#include "Transport.h"
|
[clangd] Move non-clang base pieces into separate support/ lib. NFCI
Summary:
This enforces layering, reduces a sprawling clangd/ directory, and makes life
easier for embedders.
Reviewers: kbobyrev
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D79014
2020-04-28 23:49:17 +08:00
|
|
|
#include "support/Context.h"
|
2020-09-28 21:09:55 +08:00
|
|
|
#include "support/MemoryTree.h"
|
[clangd] Move non-clang base pieces into separate support/ lib. NFCI
Summary:
This enforces layering, reduces a sprawling clangd/ directory, and makes life
easier for embedders.
Reviewers: kbobyrev
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D79014
2020-04-28 23:49:17 +08:00
|
|
|
#include "support/Path.h"
|
2020-12-23 04:36:41 +08:00
|
|
|
#include "support/Threading.h"
|
2017-05-16 17:38:59 +08:00
|
|
|
#include "clang/Tooling/Core/Replacement.h"
|
2017-07-19 23:43:35 +08:00
|
|
|
#include "llvm/ADT/Optional.h"
|
2020-01-14 06:01:10 +08:00
|
|
|
#include "llvm/ADT/StringSet.h"
|
[clangd] Track document versions, include them with diags, enhance logs
Summary:
This ties to an LSP feature (diagnostic versioning) but really a lot
of the value is in being able to log what's happening with file versions
and queues more descriptively and clearly.
As such it's fairly invasive, for a logging patch :-\
Key decisions:
- at the LSP layer, we don't reqire the client to provide versions (LSP
makes it mandatory but we never enforced it). If not provided,
versions start at 0 and increment. DraftStore handles this.
- don't propagate magically using contexts, but rather manually:
addDocument -> ParseInputs -> (ParsedAST, Preamble, various callbacks)
Context-propagation would hide the versions from ClangdServer, which
would make producing good log messages hard
- within ClangdServer, treat versions as opaque and unordered.
std::string is a convenient type for this, and allows richer versions
for embedders. They're "mandatory" but "null" is a reasonable default.
Subscribers: ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D75582
2020-03-04 07:33:29 +08:00
|
|
|
#include "llvm/Support/JSON.h"
|
2020-09-28 21:09:55 +08:00
|
|
|
#include <chrono>
|
2020-10-13 06:10:04 +08:00
|
|
|
#include <cstddef>
|
2018-09-26 13:48:29 +08:00
|
|
|
#include <memory>
|
2017-05-16 17:38:59 +08:00
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace clangd {
|
|
|
|
|
2018-09-13 20:58:36 +08:00
|
|
|
/// This class exposes ClangdServer's capabilities via Language Server Protocol.
|
|
|
|
///
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
/// MessageHandler binds the implemented LSP methods (e.g. onInitialize) to
|
|
|
|
/// corresponding JSON-RPC methods ("initialize").
|
|
|
|
/// The server also supports $/cancelRequest (MessageHandler provides this).
|
2021-02-15 17:41:38 +08:00
|
|
|
class ClangdLSPServer : private ClangdServer::Callbacks,
|
|
|
|
private LSPBinder::RawOutgoing {
|
2017-05-16 17:38:59 +08:00
|
|
|
public:
|
2020-09-29 16:37:46 +08:00
|
|
|
struct Options : ClangdServer::Options {
|
2021-01-21 05:34:24 +08:00
|
|
|
/// Supplies configuration (overrides ClangdServer::ContextProvider).
|
|
|
|
config::Provider *ConfigProvider = nullptr;
|
2020-09-29 16:37:46 +08:00
|
|
|
/// Look for compilation databases, rather than using compile commands
|
|
|
|
/// set via LSP (extensions) only.
|
|
|
|
bool UseDirBasedCDB = true;
|
|
|
|
/// The offset-encoding to use, or None to negotiate it over LSP.
|
2020-09-30 16:56:43 +08:00
|
|
|
llvm::Optional<OffsetEncoding> Encoding;
|
2020-12-22 15:44:20 +08:00
|
|
|
/// If set, periodically called to release memory.
|
|
|
|
/// Consider malloc_trim(3)
|
|
|
|
std::function<void()> MemoryCleanup = nullptr;
|
2020-09-29 16:37:46 +08:00
|
|
|
|
|
|
|
/// Per-feature options. Generally ClangdServer lets these vary
|
|
|
|
/// per-request, but LSP allows limited/no customizations.
|
|
|
|
clangd::CodeCompleteOptions CodeComplete;
|
2021-12-09 16:36:04 +08:00
|
|
|
MarkupKind SignatureHelpDocumentationFormat = MarkupKind::PlainText;
|
2020-09-29 16:37:46 +08:00
|
|
|
clangd::RenameOptions Rename;
|
2020-10-02 17:34:40 +08:00
|
|
|
/// Returns true if the tweak should be enabled.
|
|
|
|
std::function<bool(const Tweak &)> TweakFilter = [](const Tweak &T) {
|
|
|
|
return !T.hidden(); // only enable non-hidden tweaks.
|
|
|
|
};
|
2021-04-26 11:46:51 +08:00
|
|
|
|
2021-05-06 05:39:37 +08:00
|
|
|
/// Limit the number of references returned (0 means no limit).
|
|
|
|
size_t ReferencesLimit = 0;
|
2020-09-29 16:37:46 +08:00
|
|
|
};
|
|
|
|
|
2020-06-18 00:09:54 +08:00
|
|
|
ClangdLSPServer(Transport &Transp, const ThreadsafeFS &TFS,
|
2020-09-29 16:37:46 +08:00
|
|
|
const ClangdLSPServer::Options &Opts);
|
[clangd] abort if shutdown takes more than a minute.
Summary:
A certain class of bug (e.g. infloop on an AST worker thread) currently means
clangd never terminates, even if the editor shuts down the protocol and closes
our stdin, and the main thread recognizes that.
Instead, let's wait 60 seconds for threads to finish cleanly, and then crash
if they haven't.
(Obviously, we should still fix these bugs).
Reviewers: kadircet
Subscribers: MaskRay, jkorous, arphaman, jfb, usaxena95, cfe-commits, ilya-biryukov
Tags: #clang
Differential Revision: https://reviews.llvm.org/D69329
2019-10-23 17:11:18 +08:00
|
|
|
/// The destructor blocks on any outstanding background tasks.
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
~ClangdLSPServer();
|
2017-05-16 17:38:59 +08:00
|
|
|
|
[clangd] Refactor JSON-over-stdin/stdout code into Transport abstraction. (re-land r344620)
Summary:
This paves the way for alternative transports (mac XPC, maybe messagepack?),
and also generally improves layering: testing ClangdLSPServer becomes less of
a pipe dream, we split up the JSONOutput monolith, etc.
This isn't a final state, much of what remains in JSONRPCDispatcher can go away,
handlers can call reply() on the transport directly, JSONOutput can be renamed
to StreamLogger and removed, etc. But this patch is sprawling already.
The main observable change (see tests) is that hitting EOF on input is now an
error: the client should send the 'exit' notification.
This is defensible: the protocol doesn't spell this case out. Reproducing the
current behavior for all combinations of shutdown/exit/EOF clutters interfaces.
We can iterate on this if desired.
Reviewers: jkorous, ioeric, hokein
Subscribers: mgorny, ilya-biryukov, MaskRay, arphaman, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53286
llvm-svn: 344672
2018-10-17 15:32:05 +08:00
|
|
|
/// Run LSP server loop, communicating with the Transport provided in the
|
|
|
|
/// constructor. This method must not be executed more than once.
|
2017-10-25 16:45:41 +08:00
|
|
|
///
|
[clangd] Refactor JSON-over-stdin/stdout code into Transport abstraction. (re-land r344620)
Summary:
This paves the way for alternative transports (mac XPC, maybe messagepack?),
and also generally improves layering: testing ClangdLSPServer becomes less of
a pipe dream, we split up the JSONOutput monolith, etc.
This isn't a final state, much of what remains in JSONRPCDispatcher can go away,
handlers can call reply() on the transport directly, JSONOutput can be renamed
to StreamLogger and removed, etc. But this patch is sprawling already.
The main observable change (see tests) is that hitting EOF on input is now an
error: the client should send the 'exit' notification.
This is defensible: the protocol doesn't spell this case out. Reproducing the
current behavior for all combinations of shutdown/exit/EOF clutters interfaces.
We can iterate on this if desired.
Reviewers: jkorous, ioeric, hokein
Subscribers: mgorny, ilya-biryukov, MaskRay, arphaman, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53286
llvm-svn: 344672
2018-10-17 15:32:05 +08:00
|
|
|
/// \return Whether we shut down cleanly with a 'shutdown' -> 'exit' sequence.
|
|
|
|
bool run();
|
2017-05-16 17:38:59 +08:00
|
|
|
|
2020-09-28 21:09:55 +08:00
|
|
|
/// Profiles resource-usage.
|
|
|
|
void profile(MemoryTree &MT) const;
|
|
|
|
|
2017-05-16 22:40:30 +08:00
|
|
|
private:
|
2020-01-24 21:08:56 +08:00
|
|
|
// Implement ClangdServer::Callbacks.
|
[clangd] Track document versions, include them with diags, enhance logs
Summary:
This ties to an LSP feature (diagnostic versioning) but really a lot
of the value is in being able to log what's happening with file versions
and queues more descriptively and clearly.
As such it's fairly invasive, for a logging patch :-\
Key decisions:
- at the LSP layer, we don't reqire the client to provide versions (LSP
makes it mandatory but we never enforced it). If not provided,
versions start at 0 and increment. DraftStore handles this.
- don't propagate magically using contexts, but rather manually:
addDocument -> ParseInputs -> (ParsedAST, Preamble, various callbacks)
Context-propagation would hide the versions from ClangdServer, which
would make producing good log messages hard
- within ClangdServer, treat versions as opaque and unordered.
std::string is a convenient type for this, and allows richer versions
for embedders. They're "mandatory" but "null" is a reasonable default.
Subscribers: ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D75582
2020-03-04 07:33:29 +08:00
|
|
|
void onDiagnosticsReady(PathRef File, llvm::StringRef Version,
|
|
|
|
std::vector<Diag> Diagnostics) override;
|
2018-12-20 23:39:12 +08:00
|
|
|
void onFileUpdated(PathRef File, const TUStatus &Status) override;
|
[clangd] Show background index status using LSP 3.15 work-done progress notifications
Summary:
It simply shows the completed/total items on the background queue, e.g.
indexing: 233/1000
The denominator is reset to zero every time the queue goes idle.
The protocol is fairly complicated here (requires creating a remote "progress"
resource before sending updates). We implement the full protocol, but I've added
an extension allowing it to be skipped to reduce the burden on clients - in
particular the lit test takes this shortcut.
The addition of background index progress to DiagnosticConsumer seems ridiculous
at first glance, but I believe that interface is trending in the direction of
"ClangdServer callbacks" anyway. It's due for a rename, but otherwise actually
fits.
Reviewers: kadircet, usaxena95
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, jfb, cfe-commits, llvm-commits
Tags: #clang, #llvm
Differential Revision: https://reviews.llvm.org/D73218
2020-01-23 02:41:45 +08:00
|
|
|
void onBackgroundIndexProgress(const BackgroundQueue::Stats &Stats) override;
|
2021-02-26 21:44:01 +08:00
|
|
|
void onSemanticsMaybeChanged(PathRef File) override;
|
2017-09-30 18:08:52 +08:00
|
|
|
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
// LSP methods. Notifications have signature void(const Params&).
|
|
|
|
// Calls have signature void(const Params&, Callback<Response>).
|
|
|
|
void onInitialize(const InitializeParams &, Callback<llvm::json::Value>);
|
2020-03-03 19:12:14 +08:00
|
|
|
void onInitialized(const InitializedParams &);
|
2021-02-12 05:47:58 +08:00
|
|
|
void onShutdown(const NoParams &, Callback<std::nullptr_t>);
|
|
|
|
void onSync(const NoParams &, Callback<std::nullptr_t>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onDocumentDidOpen(const DidOpenTextDocumentParams &);
|
|
|
|
void onDocumentDidChange(const DidChangeTextDocumentParams &);
|
|
|
|
void onDocumentDidClose(const DidCloseTextDocumentParams &);
|
2020-04-10 09:27:37 +08:00
|
|
|
void onDocumentDidSave(const DidSaveTextDocumentParams &);
|
2020-10-17 02:03:48 +08:00
|
|
|
void onAST(const ASTParams &, Callback<llvm::Optional<ASTNode>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onDocumentOnTypeFormatting(const DocumentOnTypeFormattingParams &,
|
|
|
|
Callback<std::vector<TextEdit>>);
|
|
|
|
void onDocumentRangeFormatting(const DocumentRangeFormattingParams &,
|
|
|
|
Callback<std::vector<TextEdit>>);
|
|
|
|
void onDocumentFormatting(const DocumentFormattingParams &,
|
|
|
|
Callback<std::vector<TextEdit>>);
|
2018-11-23 23:21:19 +08:00
|
|
|
// The results are serialized 'vector<DocumentSymbol>' if
|
|
|
|
// SupportsHierarchicalDocumentSymbol is true and 'vector<SymbolInformation>'
|
|
|
|
// otherwise.
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onDocumentSymbol(const DocumentSymbolParams &,
|
2018-11-23 23:21:19 +08:00
|
|
|
Callback<llvm::json::Value>);
|
[clangd] Implement textDocument/foldingRange
Summary:
This patch introduces basic textDocument/foldingRange support. It relies on
textDocument/documentSymbols to collect all symbols and uses takes ranges
to create folds.
The next steps for textDocument/foldingRange support would be:
* Implementing FoldingRangeClientCapabilities and respecting respect client
preferences
* Specifying folding range kind
* Migrating from DocumentSymbol implementation to custom RecursiveASTVisitor flow that will allow more flexibility
* Supporting more folding range types: comments, PP conditional regions, includes and other code regions (e.g. public/private/protected sections of classes, control flow statement bodies)
Tested: (Neo)Vim (coc-clangd) and VSCode.
Related issue: https://github.com/clangd/clangd/issues/310
Reviewers: sammccall
Reviewed By: sammccall
Subscribers: nridge, ilya-biryukov, MaskRay, jkorous, arphaman, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D82436
2020-07-14 15:28:38 +08:00
|
|
|
void onFoldingRange(const FoldingRangeParams &,
|
|
|
|
Callback<std::vector<FoldingRange>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onCodeAction(const CodeActionParams &, Callback<llvm::json::Value>);
|
2019-01-03 21:37:12 +08:00
|
|
|
void onCompletion(const CompletionParams &, Callback<CompletionList>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onSignatureHelp(const TextDocumentPositionParams &,
|
|
|
|
Callback<SignatureHelp>);
|
[clangd] Implement textDocument/declaration from LSP 3.14
Summary:
LSP now reflects the declaration/definition distinction.
Language server changes:
- textDocument/definition now returns a definition if one is found, otherwise
the declaration. It no longer returns declaration + definition if they are
distinct.
- textDocument/declaration returns the best declaration we can find.
- For macros, the active macro definition is returned for both methods.
- For include directive, the top of the target file is returned for both.
There doesn't appear to be a discovery mechanism (we can't return everything to
clients that only know about definition), so this changes existing behavior.
In practice, it should greatly reduce the fraction of the time we need to show
the user a menu of options.
C++ API changes:
- findDefinitions is replaced by locateSymbolAt, which returns a
vector<LocatedSymbol> - one for each symbol under the cursor.
- this contains the preferred declaration, the definition (if found), and
the symbol name
This API enables some potentially-neat extensions, like swapping between decl
and def, and exposing the symbol name to the UI in the case of multiple symbols.
Reviewers: hokein
Subscribers: ilya-biryukov, javed.absar, ioeric, MaskRay, jkorous, arphaman, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D57388
llvm-svn: 352864
2019-02-01 19:26:13 +08:00
|
|
|
void onGoToDeclaration(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<Location>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onGoToDefinition(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<Location>>);
|
2021-12-31 22:40:56 +08:00
|
|
|
void onGoToType(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<Location>>);
|
2020-11-18 20:25:09 +08:00
|
|
|
void onGoToImplementation(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<Location>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onReference(const ReferenceParams &, Callback<std::vector<Location>>);
|
|
|
|
void onSwitchSourceHeader(const TextDocumentIdentifier &,
|
2019-05-07 16:30:32 +08:00
|
|
|
Callback<llvm::Optional<URIForFile>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onDocumentHighlight(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<DocumentHighlight>>);
|
|
|
|
void onFileEvent(const DidChangeWatchedFilesParams &);
|
|
|
|
void onWorkspaceSymbol(const WorkspaceSymbolParams &,
|
|
|
|
Callback<std::vector<SymbolInformation>>);
|
2019-07-24 15:49:23 +08:00
|
|
|
void onPrepareRename(const TextDocumentPositionParams &,
|
|
|
|
Callback<llvm::Optional<Range>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onRename(const RenameParams &, Callback<WorkspaceEdit>);
|
|
|
|
void onHover(const TextDocumentPositionParams &,
|
|
|
|
Callback<llvm::Optional<Hover>>);
|
[clangd] Add support for type hierarchy (super types only for now)
Summary:
Patch by Nathan Ridge(@nridge)!
This is an LSP extension proposed here:
https://github.com/Microsoft/vscode-languageserver-node/pull/426
An example client implementation can be found here:
https://github.com/theia-ide/theia/pull/3802
Reviewers: kadircet, sammccall
Reviewed By: kadircet
Subscribers: jdoerfert, sammccall, cfe-commits, mgorny, dschaefer, simark, ilya-biryukov, ioeric, MaskRay, jkorous, arphaman, kadircet
Tags: #clang
Differential Revision: https://reviews.llvm.org/D56370
llvm-svn: 356445
2019-03-19 17:27:04 +08:00
|
|
|
void onTypeHierarchy(const TypeHierarchyParams &,
|
|
|
|
Callback<llvm::Optional<TypeHierarchyItem>>);
|
2019-07-13 11:24:48 +08:00
|
|
|
void onResolveTypeHierarchy(const ResolveTypeHierarchyItemParams &,
|
|
|
|
Callback<llvm::Optional<TypeHierarchyItem>>);
|
2020-11-16 11:45:17 +08:00
|
|
|
void onPrepareCallHierarchy(const CallHierarchyPrepareParams &,
|
|
|
|
Callback<std::vector<CallHierarchyItem>>);
|
|
|
|
void onCallHierarchyIncomingCalls(
|
|
|
|
const CallHierarchyIncomingCallsParams &,
|
|
|
|
Callback<std::vector<CallHierarchyIncomingCall>>);
|
|
|
|
void onCallHierarchyOutgoingCalls(
|
|
|
|
const CallHierarchyOutgoingCallsParams &,
|
|
|
|
Callback<std::vector<CallHierarchyOutgoingCall>>);
|
2021-02-22 15:55:13 +08:00
|
|
|
void onInlayHints(const InlayHintsParams &, Callback<std::vector<InlayHint>>);
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
void onChangeConfiguration(const DidChangeConfigurationParams &);
|
2018-11-28 00:40:46 +08:00
|
|
|
void onSymbolInfo(const TextDocumentPositionParams &,
|
|
|
|
Callback<std::vector<SymbolDetails>>);
|
2019-09-24 21:38:33 +08:00
|
|
|
void onSelectionRange(const SelectionRangeParams &,
|
|
|
|
Callback<std::vector<SelectionRange>>);
|
2019-12-17 02:08:51 +08:00
|
|
|
void onDocumentLink(const DocumentLinkParams &,
|
|
|
|
Callback<std::vector<DocumentLink>>);
|
2020-03-24 09:24:47 +08:00
|
|
|
void onSemanticTokens(const SemanticTokensParams &, Callback<SemanticTokens>);
|
2020-07-10 22:08:14 +08:00
|
|
|
void onSemanticTokensDelta(const SemanticTokensDeltaParams &,
|
|
|
|
Callback<SemanticTokensOrDelta>);
|
2020-10-13 06:10:04 +08:00
|
|
|
/// This is a clangd extension. Provides a json tree representing memory usage
|
|
|
|
/// hierarchy.
|
2021-02-12 05:47:58 +08:00
|
|
|
void onMemoryUsage(const NoParams &, Callback<MemoryTree>);
|
2021-02-11 23:32:09 +08:00
|
|
|
void onCommand(const ExecuteCommandParams &, Callback<llvm::json::Value>);
|
|
|
|
|
|
|
|
/// Implement commands.
|
|
|
|
void onCommandApplyEdit(const WorkspaceEdit &, Callback<llvm::json::Value>);
|
|
|
|
void onCommandApplyTweak(const TweakArgs &, Callback<llvm::json::Value>);
|
|
|
|
|
2021-02-15 17:41:38 +08:00
|
|
|
/// Outgoing LSP calls.
|
|
|
|
LSPBinder::OutgoingMethod<ApplyWorkspaceEditParams,
|
|
|
|
ApplyWorkspaceEditResponse>
|
|
|
|
ApplyWorkspaceEdit;
|
|
|
|
LSPBinder::OutgoingNotification<ShowMessageParams> ShowMessage;
|
|
|
|
LSPBinder::OutgoingNotification<PublishDiagnosticsParams> PublishDiagnostics;
|
|
|
|
LSPBinder::OutgoingNotification<FileStatus> NotifyFileStatus;
|
|
|
|
LSPBinder::OutgoingMethod<WorkDoneProgressCreateParams, std::nullptr_t>
|
|
|
|
CreateWorkDoneProgress;
|
|
|
|
LSPBinder::OutgoingNotification<ProgressParams<WorkDoneProgressBegin>>
|
|
|
|
BeginWorkDoneProgress;
|
|
|
|
LSPBinder::OutgoingNotification<ProgressParams<WorkDoneProgressReport>>
|
|
|
|
ReportWorkDoneProgress;
|
|
|
|
LSPBinder::OutgoingNotification<ProgressParams<WorkDoneProgressEnd>>
|
|
|
|
EndWorkDoneProgress;
|
2021-02-26 21:44:01 +08:00
|
|
|
LSPBinder::OutgoingMethod<NoParams, std::nullptr_t> SemanticTokensRefresh;
|
2021-02-15 17:41:38 +08:00
|
|
|
|
2021-02-11 23:32:09 +08:00
|
|
|
void applyEdit(WorkspaceEdit WE, llvm::json::Value Success,
|
|
|
|
Callback<llvm::json::Value> Reply);
|
|
|
|
|
2021-02-26 21:44:01 +08:00
|
|
|
void bindMethods(LSPBinder &, const ClientCapabilities &Caps);
|
2018-03-12 23:28:22 +08:00
|
|
|
std::vector<Fix> getFixes(StringRef File, const clangd::Diagnostic &D);
|
2017-05-16 17:38:59 +08:00
|
|
|
|
2019-01-03 21:37:12 +08:00
|
|
|
/// Checks if completion request should be ignored. We need this due to the
|
|
|
|
/// limitation of the LSP. Per LSP, a client sends requests for all "trigger
|
|
|
|
/// character" we specify, but for '>' and ':' we need to check they actually
|
|
|
|
/// produce '->' and '::', respectively.
|
|
|
|
bool shouldRunCompletion(const CompletionParams &Params) const;
|
|
|
|
|
2018-10-25 12:22:52 +08:00
|
|
|
void applyConfiguration(const ConfigurationSettings &Settings);
|
2018-03-16 22:30:42 +08:00
|
|
|
|
2020-09-28 21:09:55 +08:00
|
|
|
/// Runs profiling and exports memory usage metrics if tracing is enabled and
|
|
|
|
/// profiling hasn't happened recently.
|
|
|
|
void maybeExportMemoryProfile();
|
2020-12-23 04:36:41 +08:00
|
|
|
PeriodicThrottler ShouldProfile;
|
2020-09-28 21:09:55 +08:00
|
|
|
|
2020-12-22 15:44:20 +08:00
|
|
|
/// Run the MemoryCleanup callback if it's time.
|
|
|
|
/// This method is thread safe.
|
|
|
|
void maybeCleanupMemory();
|
2020-12-23 04:36:41 +08:00
|
|
|
PeriodicThrottler ShouldCleanupMemory;
|
2020-12-22 15:44:20 +08:00
|
|
|
|
2019-10-15 22:59:08 +08:00
|
|
|
/// Since initialization of CDBs and ClangdServer is done lazily, the
|
|
|
|
/// following context captures the one used while creating ClangdLSPServer and
|
|
|
|
/// passes it to above mentioned object instances to make sure they share the
|
|
|
|
/// same state.
|
2019-10-15 22:20:52 +08:00
|
|
|
Context BackgroundContext;
|
|
|
|
|
2017-05-16 22:40:30 +08:00
|
|
|
/// Used to indicate that the 'shutdown' request was received from the
|
|
|
|
/// Language Server client.
|
2017-10-25 16:45:41 +08:00
|
|
|
bool ShutdownRequestReceived = false;
|
|
|
|
|
2019-08-05 20:48:09 +08:00
|
|
|
/// Used to indicate the ClangdLSPServer is being destroyed.
|
|
|
|
std::atomic<bool> IsBeingDestroyed = {false};
|
|
|
|
|
2017-05-16 17:38:59 +08:00
|
|
|
std::mutex FixItsMutex;
|
2018-03-12 23:28:22 +08:00
|
|
|
typedef std::map<clangd::Diagnostic, std::vector<Fix>, LSPDiagnosticCompare>
|
2017-05-16 17:38:59 +08:00
|
|
|
DiagnosticToReplacementMap;
|
|
|
|
/// Caches FixIts per file and diagnostics
|
|
|
|
llvm::StringMap<DiagnosticToReplacementMap> FixItsMap;
|
[clangd] Support textDocument/semanticTokens/edits
Summary:
This returns incremental highlights as a set of edits against the
previous highlights.
Server-side, we compute the full set of highlights, this just saves
wire-format size.
For now, the diff used is trivial: everything from the first change to
the last change is sent as a single edit.
The wire format is grungy - the replacement offset/length refer to
positions in the encoded array instead of the logical list of tokens.
We use token-oriented structs and translating to LSP forms when serializing.
This departs from LSP (but is consistent with semanticTokens today).
Tested in VSCode insiders (with a patched client to enable experimental
features).
Reviewers: hokein
Subscribers: ilya-biryukov, MaskRay, jkorous, mgrang, arphaman, kadircet, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D77225
2020-04-01 22:21:44 +08:00
|
|
|
// Last semantic-tokens response, for incremental requests.
|
|
|
|
std::mutex SemanticTokensMutex;
|
|
|
|
llvm::StringMap<SemanticTokens> LastSemanticTokens;
|
2017-06-13 23:59:43 +08:00
|
|
|
|
2021-02-15 17:41:38 +08:00
|
|
|
// Most code should not deal with Transport, callMethod, notify directly.
|
|
|
|
// Use LSPBinder to handle incoming and outgoing calls.
|
[clangd] Refactor JSON-over-stdin/stdout code into Transport abstraction. (re-land r344620)
Summary:
This paves the way for alternative transports (mac XPC, maybe messagepack?),
and also generally improves layering: testing ClangdLSPServer becomes less of
a pipe dream, we split up the JSONOutput monolith, etc.
This isn't a final state, much of what remains in JSONRPCDispatcher can go away,
handlers can call reply() on the transport directly, JSONOutput can be renamed
to StreamLogger and removed, etc. But this patch is sprawling already.
The main observable change (see tests) is that hitting EOF on input is now an
error: the client should send the 'exit' notification.
This is defensible: the protocol doesn't spell this case out. Reproducing the
current behavior for all combinations of shutdown/exit/EOF clutters interfaces.
We can iterate on this if desired.
Reviewers: jkorous, ioeric, hokein
Subscribers: mgorny, ilya-biryukov, MaskRay, arphaman, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53286
llvm-svn: 344672
2018-10-17 15:32:05 +08:00
|
|
|
clangd::Transport &Transp;
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
class MessageHandler;
|
|
|
|
std::unique_ptr<MessageHandler> MsgHandler;
|
|
|
|
std::mutex TranspWriter;
|
2019-08-05 20:48:09 +08:00
|
|
|
|
2021-02-15 17:41:38 +08:00
|
|
|
void callMethod(StringRef Method, llvm::json::Value Params,
|
|
|
|
Callback<llvm::json::Value> CB) override;
|
|
|
|
void notify(StringRef Method, llvm::json::Value Params) override;
|
2021-02-12 05:47:58 +08:00
|
|
|
|
|
|
|
LSPBinder::RawHandlers Handlers;
|
[clangd] Lay JSONRPCDispatcher to rest.
Summary:
Most of its functionality is moved into ClangdLSPServer.
The decoupling between JSONRPCDispatcher, ProtocolCallbacks, ClangdLSPServer
was never real, and only served to obfuscate.
Some previous implicit/magic stuff is now explicit:
- the return type of LSP method calls are now in the signature
- no more reply() that gets the ID using global context magic
- arg tracing no longer relies on RequestArgs::stash context magic either
This is mostly refactoring, but some deliberate fixes while here:
- LSP method params are now by const reference
- notifications and calls are now distinct namespaces.
(some tests had protocol errors and needed updating)
- we now reply to calls we failed to decode
- outgoing calls use distinct IDs
A few error codes and message IDs changed in unimportant ways (see tests).
Reviewers: ioeric
Subscribers: mgorny, ilya-biryukov, javed.absar, MaskRay, jkorous, arphaman, jfb, kadircet, cfe-commits
Differential Revision: https://reviews.llvm.org/D53387
llvm-svn: 344737
2018-10-18 20:32:04 +08:00
|
|
|
|
2020-06-18 00:09:54 +08:00
|
|
|
const ThreadsafeFS &TFS;
|
2018-08-11 01:25:07 +08:00
|
|
|
/// Options used for diagnostics.
|
|
|
|
ClangdDiagnosticOptions DiagOpts;
|
[clangd] Implementation of workspace/symbol request
Summary:
This is a basic implementation of the "workspace/symbol" request which is
used to find symbols by a string query. Since this is similar to code completion
in terms of result, this implementation reuses the "fuzzyFind" in order to get
matches. For now, the scoring algorithm is the same as code completion and
improvements could be done in the future.
The index model doesn't contain quite enough symbols for this to cover
common symbols like methods, enum class enumerators, functions in unamed
namespaces, etc. The index model will be augmented separately to achieve this.
Reviewers: sammccall, ilya-biryukov
Reviewed By: sammccall
Subscribers: jkorous, hokein, simark, sammccall, klimek, mgorny, ilya-biryukov, mgrang, jkorous-apple, ioeric, MaskRay, cfe-commits
Differential Revision: https://reviews.llvm.org/D44882
llvm-svn: 330637
2018-04-24 04:00:52 +08:00
|
|
|
/// The supported kinds of the client.
|
|
|
|
SymbolKindBitset SupportedSymbolKinds;
|
2018-09-28 01:13:07 +08:00
|
|
|
/// The supported completion item kinds of the client.
|
|
|
|
CompletionItemKindBitset SupportedCompletionItemKinds;
|
2018-12-20 23:39:12 +08:00
|
|
|
/// Whether the client supports CodeAction response objects.
|
2018-10-17 00:29:41 +08:00
|
|
|
bool SupportsCodeAction = false;
|
2018-11-23 23:21:19 +08:00
|
|
|
/// From capabilities of textDocument/documentSymbol.
|
|
|
|
bool SupportsHierarchicalDocumentSymbol = false;
|
2018-12-20 23:39:12 +08:00
|
|
|
/// Whether the client supports showing file status.
|
|
|
|
bool SupportFileStatus = false;
|
2019-05-29 18:01:00 +08:00
|
|
|
/// Which kind of markup should we use in textDocument/hover responses.
|
|
|
|
MarkupKind HoverContentFormat = MarkupKind::PlainText;
|
2019-06-04 17:36:59 +08:00
|
|
|
/// Whether the client supports offsets for parameter info labels.
|
|
|
|
bool SupportsOffsetsInSignatureHelp = false;
|
[clangd] Show background index status using LSP 3.15 work-done progress notifications
Summary:
It simply shows the completed/total items on the background queue, e.g.
indexing: 233/1000
The denominator is reset to zero every time the queue goes idle.
The protocol is fairly complicated here (requires creating a remote "progress"
resource before sending updates). We implement the full protocol, but I've added
an extension allowing it to be skipped to reduce the burden on clients - in
particular the lit test takes this shortcut.
The addition of background index progress to DiagnosticConsumer seems ridiculous
at first glance, but I believe that interface is trending in the direction of
"ClangdServer callbacks" anyway. It's due for a rename, but otherwise actually
fits.
Reviewers: kadircet, usaxena95
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, jfb, cfe-commits, llvm-commits
Tags: #clang, #llvm
Differential Revision: https://reviews.llvm.org/D73218
2020-01-23 02:41:45 +08:00
|
|
|
std::mutex BackgroundIndexProgressMutex;
|
|
|
|
enum class BackgroundIndexProgress {
|
|
|
|
// Client doesn't support reporting progress. No transitions possible.
|
|
|
|
Unsupported,
|
|
|
|
// The queue is idle, and the client has no progress bar.
|
|
|
|
// Can transition to Creating when we have some activity.
|
|
|
|
Empty,
|
|
|
|
// We've requested the client to create a progress bar.
|
|
|
|
// Meanwhile, the state is buffered in PendingBackgroundIndexProgress.
|
|
|
|
Creating,
|
|
|
|
// The client has a progress bar, and we can send it updates immediately.
|
|
|
|
Live,
|
|
|
|
} BackgroundIndexProgressState = BackgroundIndexProgress::Unsupported;
|
|
|
|
// The progress to send when the progress bar is created.
|
|
|
|
// Only valid in state Creating.
|
|
|
|
BackgroundQueue::Stats PendingBackgroundIndexProgress;
|
|
|
|
/// LSP extension: skip WorkDoneProgressCreate, just send progress streams.
|
|
|
|
bool BackgroundIndexSkipCreate = false;
|
2018-03-16 22:30:42 +08:00
|
|
|
|
2020-09-29 16:37:46 +08:00
|
|
|
Options Opts;
|
2018-10-23 22:19:54 +08:00
|
|
|
// The CDB is created by the "initialize" LSP method.
|
2018-11-02 21:09:36 +08:00
|
|
|
std::unique_ptr<GlobalCompilationDatabase> BaseCDB;
|
2020-01-04 23:28:41 +08:00
|
|
|
// CDB is BaseCDB plus any commands overridden via LSP extensions.
|
2018-11-02 21:09:36 +08:00
|
|
|
llvm::Optional<OverlayCDB> CDB;
|
[clangd] abort if shutdown takes more than a minute.
Summary:
A certain class of bug (e.g. infloop on an AST worker thread) currently means
clangd never terminates, even if the editor shuts down the protocol and closes
our stdin, and the main thread recognizes that.
Instead, let's wait 60 seconds for threads to finish cleanly, and then crash
if they haven't.
(Obviously, we should still fix these bugs).
Reviewers: kadircet
Subscribers: MaskRay, jkorous, arphaman, jfb, usaxena95, cfe-commits, ilya-biryukov
Tags: #clang
Differential Revision: https://reviews.llvm.org/D69329
2019-10-23 17:11:18 +08:00
|
|
|
// The ClangdServer is created by the "initialize" LSP method.
|
|
|
|
llvm::Optional<ClangdServer> Server;
|
2018-08-24 21:09:41 +08:00
|
|
|
};
|
2017-05-16 17:38:59 +08:00
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|
|
|
|
|
2018-08-15 00:03:32 +08:00
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_CLANGD_CLANGDLSPSERVER_H
|