//===--- Driver.h - Clang GCC Compatible Driver -----------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef CLANG_DRIVER_DRIVER_H_ #define CLANG_DRIVER_DRIVER_H_ #include "clang/Basic/Diagnostic.h" #include "clang/Driver/Phases.h" #include "clang/Driver/Util.h" #include "llvm/ADT/StringRef.h" #include "llvm/ADT/Triple.h" #include "llvm/System/Path.h" // FIXME: Kill when CompilationInfo // lands. #include #include #include namespace llvm { class raw_ostream; } namespace clang { namespace driver { class Action; class ArgList; class Compilation; class DerivedArgList; class HostInfo; class InputArgList; class InputInfo; class JobAction; class OptTable; class ToolChain; /// Driver - Encapsulate logic for constructing compilation processes /// from a set of gcc-driver-like command line arguments. class Driver { OptTable *Opts; Diagnostic &Diags; public: // Diag - Forwarding function for diagnostics. DiagnosticBuilder Diag(unsigned DiagID) const { return Diags.Report(DiagID); } // FIXME: Privatize once interface is stable. public: /// The name the driver was invoked as. std::string Name; /// The path the driver executable was in, as invoked from the /// command line. std::string Dir; /// The original path to the clang executable. std::string ClangExecutable; /// The path to the installed clang directory, if any. std::string InstalledDir; /// The path to the compiler resource directory. std::string ResourceDir; /// A prefix directory used to emulated a limited subset of GCC's '-Bprefix' /// functionality. /// FIXME: This type of customization should be removed in favor of the /// universal driver when it is ready. std::string PrefixDir; /// Default host triple. std::string DefaultHostTriple; /// Default name for linked images (e.g., "a.out"). std::string DefaultImageName; /// Driver title to use with help. std::string DriverTitle; /// Host information for the platform the driver is running as. This /// will generally be the actual host platform, but not always. const HostInfo *Host; /// Information about the host which can be overriden by the user. std::string HostBits, HostMachine, HostSystem, HostRelease; /// Name to use when calling the generic gcc. std::string CCCGenericGCCName; /// The file to log CC_PRINT_OPTIONS output to, if enabled. const char *CCPrintOptionsFilename; /// Whether the driver should follow g++ like behavior. unsigned CCCIsCXX : 1; /// Echo commands while executing (in -v style). unsigned CCCEcho : 1; /// Only print tool bindings, don't build any jobs. unsigned CCCPrintBindings : 1; /// Set CC_PRINT_OPTIONS mode, which is like -v but logs the commands to /// CCPrintOptionsFilename or to stderr. unsigned CCPrintOptions : 1; private: /// Whether to check that input files exist when constructing compilation /// jobs. unsigned CheckInputsExist : 1; /// Use the clang compiler where possible. unsigned CCCUseClang : 1; /// Use clang for handling C++ and Objective-C++ inputs. unsigned CCCUseClangCXX : 1; /// Use clang as a preprocessor (clang's preprocessor will still be /// used where an integrated CPP would). unsigned CCCUseClangCPP : 1; public: /// Use lazy precompiled headers for PCH support. unsigned CCCUsePCH : 1; private: /// Only use clang for the given architectures (only used when /// non-empty). std::set CCCClangArchs; /// Certain options suppress the 'no input files' warning. bool SuppressMissingInputWarning : 1; std::list TempFiles; std::list ResultFiles; private: /// TranslateInputArgs - Create a new derived argument list from the input /// arguments, after applying the standard argument translations. DerivedArgList *TranslateInputArgs(const InputArgList &Args) const; public: Driver(llvm::StringRef _ClangExecutable, llvm::StringRef _DefaultHostTriple, llvm::StringRef _DefaultImageName, bool IsProduction, bool CXXIsProduction, Diagnostic &_Diags); ~Driver(); /// @name Accessors /// @{ const OptTable &getOpts() const { return *Opts; } const Diagnostic &getDiags() const { return Diags; } bool getCheckInputsExist() const { return CheckInputsExist; } void setCheckInputsExist(bool Value) { CheckInputsExist = Value; } const std::string &getTitle() { return DriverTitle; } void setTitle(std::string Value) { DriverTitle = Value; } /// \brief Get the path to the main clang executable. const char *getClangProgramPath() const { return ClangExecutable.c_str(); } /// \brief Get the path to where the clang executable was installed. const char *getInstalledDir() const { if (!InstalledDir.empty()) return InstalledDir.c_str(); return Dir.c_str(); } void setInstalledDir(llvm::StringRef Value) { InstalledDir = Value; } /// @} /// @name Primary Functionality /// @{ /// BuildCompilation - Construct a compilation object for a command /// line argument vector. /// /// \return A compilation, or 0 if none was built for the given /// argument vector. A null return value does not necessarily /// indicate an error condition, the diagnostics should be queried /// to determine if an error occurred. Compilation *BuildCompilation(int argc, const char **argv); /// @name Driver Steps /// @{ /// ParseArgStrings - Parse the given list of strings into an /// ArgList. InputArgList *ParseArgStrings(const char **ArgBegin, const char **ArgEnd); /// BuildActions - Construct the list of actions to perform for the /// given arguments, which are only done for a single architecture. /// /// \param TC - The default host tool chain. /// \param Args - The input arguments. /// \param Actions - The list to store the resulting actions onto. void BuildActions(const ToolChain &TC, const ArgList &Args, ActionList &Actions) const; /// BuildUniversalActions - Construct the list of actions to perform /// for the given arguments, which may require a universal build. /// /// \param TC - The default host tool chain. /// \param Args - The input arguments. /// \param Actions - The list to store the resulting actions onto. void BuildUniversalActions(const ToolChain &TC, const ArgList &Args, ActionList &Actions) const; /// BuildJobs - Bind actions to concrete tools and translate /// arguments to form the list of jobs to run. /// /// \arg C - The compilation that is being built. void BuildJobs(Compilation &C) const; /// ExecuteCompilation - Execute the compilation according to the command line /// arguments and return an appropriate exit code. /// /// This routine handles additional processing that must be done in addition /// to just running the subprocesses, for example reporting errors, removing /// temporary files, etc. int ExecuteCompilation(const Compilation &C) const; /// @} /// @name Helper Methods /// @{ /// PrintActions - Print the list of actions. void PrintActions(const Compilation &C) const; /// PrintHelp - Print the help text. /// /// \param ShowHidden - Show hidden options. void PrintHelp(bool ShowHidden) const; /// PrintOptions - Print the list of arguments. void PrintOptions(const ArgList &Args) const; /// PrintVersion - Print the driver version. void PrintVersion(const Compilation &C, llvm::raw_ostream &OS) const; /// GetFilePath - Lookup \arg Name in the list of file search paths. /// /// \arg TC - The tool chain for additional information on /// directories to search. // // FIXME: This should be in CompilationInfo. std::string GetFilePath(const char *Name, const ToolChain &TC) const; /// GetProgramPath - Lookup \arg Name in the list of program search /// paths. /// /// \arg TC - The provided tool chain for additional information on /// directories to search. /// /// \arg WantFile - False when searching for an executable file, otherwise /// true. Defaults to false. // // FIXME: This should be in CompilationInfo. std::string GetProgramPath(const char *Name, const ToolChain &TC, bool WantFile = false) const; /// HandleImmediateArgs - Handle any arguments which should be /// treated before building actions or binding tools. /// /// \return Whether any compilation should be built for this /// invocation. bool HandleImmediateArgs(const Compilation &C); /// ConstructAction - Construct the appropriate action to do for /// \arg Phase on the \arg Input, taking in to account arguments /// like -fsyntax-only or --analyze. Action *ConstructPhaseAction(const ArgList &Args, phases::ID Phase, Action *Input) const; /// BuildJobsForAction - Construct the jobs to perform for the /// action \arg A. void BuildJobsForAction(Compilation &C, const Action *A, const ToolChain *TC, const char *BoundArch, bool AtTopLevel, const char *LinkingOutput, InputInfo &Result) const; /// GetNamedOutputPath - Return the name to use for the output of /// the action \arg JA. The result is appended to the compilation's /// list of temporary or result files, as appropriate. /// /// \param C - The compilation. /// \param JA - The action of interest. /// \param BaseInput - The original input file that this action was /// triggered by. /// \param AtTopLevel - Whether this is a "top-level" action. const char *GetNamedOutputPath(Compilation &C, const JobAction &JA, const char *BaseInput, bool AtTopLevel) const; /// GetTemporaryPath - Return the pathname of a temporary file to /// use as part of compilation; the file will have the given suffix. /// /// GCC goes to extra lengths here to be a bit more robust. std::string GetTemporaryPath(const char *Suffix) const; /// GetHostInfo - Construct a new host info object for the given /// host triple. const HostInfo *GetHostInfo(const char *HostTriple) const; /// ShouldUseClangCompilar - Should the clang compiler be used to /// handle this action. bool ShouldUseClangCompiler(const Compilation &C, const JobAction &JA, const llvm::Triple &ArchName) const; /// @} /// GetReleaseVersion - Parse (([0-9]+)(.([0-9]+)(.([0-9]+)?))?)? and /// return the grouped values as integers. Numbers which are not /// provided are set to 0. /// /// \return True if the entire string was parsed (9.2), or all /// groups were parsed (10.3.5extrastuff). HadExtra is true if all /// groups were parsed but extra characters remain at the end. static bool GetReleaseVersion(const char *Str, unsigned &Major, unsigned &Minor, unsigned &Micro, bool &HadExtra); }; } // end namespace driver } // end namespace clang #endif