//===--- 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