diff options
author | Krasimir Georgiev <krasimir@google.com> | 2017-07-19 15:43:35 +0000 |
---|---|---|
committer | Krasimir Georgiev <krasimir@google.com> | 2017-07-19 15:43:35 +0000 |
commit | 0dcb48eab1737f4801afcba1fec251b20dba8806 (patch) | |
tree | 8f66c2b5b7a70a559f27556824aef470b3330fdb | |
parent | b449dc189a3574cdb662c93da48231160877e302 (diff) | |
download | bcm5719-llvm-0dcb48eab1737f4801afcba1fec251b20dba8806.tar.gz bcm5719-llvm-0dcb48eab1737f4801afcba1fec251b20dba8806.zip |
[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
-rw-r--r-- | clang-tools-extra/clangd/ClangdLSPServer.cpp | 5 | ||||
-rw-r--r-- | clang-tools-extra/clangd/ClangdLSPServer.h | 4 | ||||
-rw-r--r-- | clang-tools-extra/clangd/tool/ClangdMain.cpp | 10 |
3 files changed, 15 insertions, 4 deletions
diff --git a/clang-tools-extra/clangd/ClangdLSPServer.cpp b/clang-tools-extra/clangd/ClangdLSPServer.cpp index e0489eb15b8..6577a6d3b48 100644 --- a/clang-tools-extra/clangd/ClangdLSPServer.cpp +++ b/clang-tools-extra/clangd/ClangdLSPServer.cpp @@ -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"); diff --git a/clang-tools-extra/clangd/ClangdLSPServer.h b/clang-tools-extra/clangd/ClangdLSPServer.h index e8e66f6052d..dd61fca98e1 100644 --- a/clang-tools-extra/clangd/ClangdLSPServer.h +++ b/clang-tools-extra/clangd/ClangdLSPServer.h @@ -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 diff --git a/clang-tools-extra/clangd/tool/ClangdMain.cpp b/clang-tools-extra/clangd/tool/ClangdMain.cpp index d67f75bacc4..199c298b21c 100644 --- a/clang-tools-extra/clangd/tool/ClangdMain.cpp +++ b/clang-tools-extra/clangd/tool/ClangdMain.cpp @@ -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); } |