Viewing file: Tool.h (3.41 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
//===--- 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<InputInfo, 4> 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 hasIntegratedBackend() const { return true; } 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
|