[clangd] Allow specifying -resource-dir

Summary: This patch allows clangd to specify its -resource-dir.

Reviewers: bkramer, klimek

Reviewed By: bkramer

Subscribers: cfe-commits

Tags: #clang-tools-extra

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

llvm-svn: 308486
This commit is contained in:
Krasimir Georgiev 2017-07-19 15:43:35 +00:00
parent b449dc189a
commit 0dcb48eab1
3 changed files with 15 additions and 4 deletions

View File

@ -216,9 +216,10 @@ void ClangdLSPServer::LSPProtocolCallbacks::onGoToDefinition(
R"(,"result":[)" + Locations + R"(]})");
}
ClangdLSPServer::ClangdLSPServer(JSONOutput &Out, bool RunSynchronously)
ClangdLSPServer::ClangdLSPServer(JSONOutput &Out, bool RunSynchronously,
llvm::Optional<StringRef> ResourceDir)
: Out(Out), DiagConsumer(*this),
Server(CDB, DiagConsumer, FSProvider, RunSynchronously) {}
Server(CDB, DiagConsumer, FSProvider, RunSynchronously, ResourceDir) {}
void ClangdLSPServer::run(std::istream &In) {
assert(!IsDone && "Run was called before");

View File

@ -15,6 +15,7 @@
#include "Path.h"
#include "Protocol.h"
#include "clang/Tooling/Core/Replacement.h"
#include "llvm/ADT/Optional.h"
namespace clang {
namespace clangd {
@ -25,7 +26,8 @@ class JSONOutput;
/// dispatch and ClangdServer together.
class ClangdLSPServer {
public:
ClangdLSPServer(JSONOutput &Out, bool RunSynchronously);
ClangdLSPServer(JSONOutput &Out, bool RunSynchronously,
llvm::Optional<StringRef> ResourceDir);
/// Run LSP server loop, receiving input for it from \p In. \p In must be
/// opened in binary mode. Output will be written using Out variable passed to

View File

@ -25,6 +25,11 @@ static llvm::cl::opt<bool>
llvm::cl::desc("parse on main thread"),
llvm::cl::init(false), llvm::cl::Hidden);
static llvm::cl::opt<std::string>
ResourceDir("resource-dir",
llvm::cl::desc("directory for system clang headers"),
llvm::cl::init(""), llvm::cl::Hidden);
int main(int argc, char *argv[]) {
llvm::cl::ParseCommandLineOptions(argc, argv, "clangd");
@ -35,6 +40,9 @@ int main(int argc, char *argv[]) {
// Change stdin to binary to not lose \r\n on windows.
llvm::sys::ChangeStdinToBinary();
ClangdLSPServer LSPServer(Out, RunSynchronously);
llvm::Optional<StringRef> ResourceDirRef = None;
if (!ResourceDir.empty())
ResourceDirRef = ResourceDir;
ClangdLSPServer LSPServer(Out, RunSynchronously, ResourceDirRef);
LSPServer.run(std::cin);
}