Index: clangd/ClangdLSPServer.h =================================================================== --- clangd/ClangdLSPServer.h +++ 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 @@ /// dispatch and ClangdServer together. class ClangdLSPServer { public: - ClangdLSPServer(JSONOutput &Out, bool RunSynchronously); + ClangdLSPServer(JSONOutput &Out, bool RunSynchronously, + llvm::Optional 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 Index: clangd/ClangdLSPServer.cpp =================================================================== --- clangd/ClangdLSPServer.cpp +++ clangd/ClangdLSPServer.cpp @@ -216,9 +216,10 @@ R"(,"result":[)" + Locations + R"(]})"); } -ClangdLSPServer::ClangdLSPServer(JSONOutput &Out, bool RunSynchronously) +ClangdLSPServer::ClangdLSPServer(JSONOutput &Out, bool RunSynchronously, + llvm::Optional 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"); Index: clangd/tool/ClangdMain.cpp =================================================================== --- clangd/tool/ClangdMain.cpp +++ clangd/tool/ClangdMain.cpp @@ -25,6 +25,11 @@ llvm::cl::desc("parse on main thread"), llvm::cl::init(false), llvm::cl::Hidden); +static llvm::cl::opt + 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 @@ // Change stdin to binary to not lose \r\n on windows. llvm::sys::ChangeStdinToBinary(); - ClangdLSPServer LSPServer(Out, RunSynchronously); + llvm::Optional ResourceDirRef = None; + if (!ResourceDir.empty()) + ResourceDirRef = ResourceDir; + ClangdLSPServer LSPServer(Out, RunSynchronously, ResourceDirRef); LSPServer.run(std::cin); }