//===--- Tool.h - Compilation Tools -----------------------------*- 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_DRIVER_TOOL_H #define LLVM_CLANG_DRIVER_TOOL_H #include "clang/Basic/LLVM.h" namespace llvm { namespace opt { class ArgList; } } namespace clang { namespace driver { class Compilation; class InputInfo; class Job; class JobAction; class ToolChain; typedef SmallVector InputInfoList; /// Tool - Information on a specific compilation tool. class Tool { /// The tool name (for debugging). const char *Name; /// The human readable name for the tool, for use in diagnostics. const char *ShortName; /// The tool chain this tool is a part of. const ToolChain &TheToolChain; public: Tool(const char *Name, const char *ShortName, const ToolChain &TC); public: virtual ~Tool(); const char *getName() const { return Name; } const char *getShortName() const { return ShortName; } const ToolChain &getToolChain() const { return TheToolChain; } virtual bool hasIntegratedAssembler() const { return false; } virtual bool canEmitIR() const { return false; } virtual bool hasIntegratedCPP() const = 0; virtual bool isLinkJob() const { return false; } virtual bool isDsymutilJob() const { return false; } /// Does this tool have "good" standardized diagnostics, or should the /// driver add an additional "command failed" diagnostic on failures. virtual bool hasGoodDiagnostics() const { return false; } /// ConstructJob - Construct jobs to perform the action \p JA, /// writing to \p Output and with \p Inputs, and add the jobs to /// \p C. /// /// \param TCArgs - The argument list for this toolchain, with any /// tool chain specific translations applied. /// \param LinkingOutput - If this output will eventually feed the /// linker, then this is the final output name of the linked image. virtual void ConstructJob(Compilation &C, const JobAction &JA, const InputInfo &Output, const InputInfoList &Inputs, const llvm::opt::ArgList &TCArgs, const char *LinkingOutput) const = 0; /// Construct jobs to perform the action \p JA, writing to the \p Outputs and /// with \p Inputs, and add the jobs to \p C. The default implementation /// assumes a single output and is expected to be overloaded for the tools /// that support multiple inputs. /// /// \param TCArgs The argument list for this toolchain, with any /// tool chain specific translations applied. /// \param LinkingOutput If this output will eventually feed the /// linker, then this is the final output name of the linked image. virtual void ConstructJobMultipleOutputs(Compilation &C, const JobAction &JA, const InputInfoList &Outputs, const InputInfoList &Inputs, const llvm::opt::ArgList &TCArgs, const char *LinkingOutput) const; }; } // end namespace driver } // end namespace clang #endif