//===--- CompileCommands.h - Manipulation of compile flags -------*- C++-*-===// // // 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 // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_COMPILECOMMANDS_H #define LLVM_CLANG_TOOLS_EXTRA_CLANGD_COMPILECOMMANDS_H #include "GlobalCompilationDatabase.h" #include "support/Threading.h" #include "llvm/ADT/StringMap.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/CommandLine.h" #include <deque> #include <optional> #include <string> #include <vector> namespace clang { namespace clangd { // CommandMangler transforms compile commands from some external source // for use in clangd. This means: // - running the frontend only, stripping args regarding output files etc // - forcing the use of clangd's builtin headers rather than clang's // - resolving argv0 as cc1 expects // - injecting -isysroot flags on mac as the system clang does struct CommandMangler { … }; // Removes args from a command-line in a semantically-aware way. // // Internally this builds a large (0.5MB) table of clang options on first use. // Both strip() and process() are fairly cheap after that. // // FIXME: this reimplements much of OptTable, it might be nice to expose more. // The table-building strategy may not make sense outside clangd. class ArgStripper { … }; // Renders an argv list, with arguments separated by spaces. // Where needed, arguments are "quoted" and escaped. std::string printArgv(llvm::ArrayRef<llvm::StringRef> Args); std::string printArgv(llvm::ArrayRef<std::string> Args); } // namespace clangd } // namespace clang #endif