| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280 | /*=========================================================================  Program:   CMake - Cross-Platform Makefile Generator  Module:    $RCSfile$  Language:  C++  Date:      $Date$  Version:   $Revision$  Copyright (c) 2002 Kitware, Inc., Insight Consortium.  All rights reserved.  See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.     This software is distributed WITHOUT ANY WARRANTY; without even      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      PURPOSE.  See the above copyright notices for more information.=========================================================================*/#ifndef cmLocalGenerator_h#define cmLocalGenerator_h#include "cmStandardIncludes.h"class cmMakefile;class cmGlobalGenerator;class cmTarget;class cmTargetManifest;class cmSourceFile;class cmCustomCommand;/** \class cmLocalGenerator * \brief Create required build files for a directory. * * Subclasses of this abstract class generate makefiles, DSP, etc for various * platforms. This class should never be constructued directly. A * GlobalGenerator will create it and invoke the appropriate commands on it. */class cmLocalGenerator{public:  cmLocalGenerator();  virtual ~cmLocalGenerator();    /**   * Generate the makefile for this directory.    */  virtual void Generate() {};  /**   * Process the CMakeLists files for this directory to fill in the   * Makefile ivar    */  virtual void Configure();  /**   * Perform any final calculations prior to generation   */  virtual void ConfigureFinalPass();  /**   * Generate the install rules files in this directory.   */  virtual void GenerateInstallRules();  /**   * Generate the test files for tests.   */  virtual void GenerateTestFiles();  /**   * Generate a manifest of target files that will be built.   */  virtual void GenerateTargetManifest(cmTargetManifest&);  ///! Get the makefile for this generator  cmMakefile *GetMakefile() {    return this->Makefile; };    ///! Get the GlobalGenerator this is associated with  cmGlobalGenerator *GetGlobalGenerator() {    return this->GlobalGenerator; };  ///! Set the Global Generator, done on creation by the GlobalGenerator  void SetGlobalGenerator(cmGlobalGenerator *gg);  /**    * Convert something to something else. This is a centralized coversion   * routine used by the generators to handle relative paths and the like.   * The flags determine what is actually done.    *   * relative: treat the argument as a directory and convert it to make it   * relative or full or unchanged. If relative (HOME, START etc) then that   * specifies what it should be relative to.   *   * output: make the result suitable for output to a...   *   * optional: should any relative path operation be controlled by the rel   * path setting   */  enum RelativeRoot { NONE, FULL, HOME, START, HOME_OUTPUT, START_OUTPUT };  enum OutputFormat { UNCHANGED, MAKEFILE, SHELL };  std::string Convert(const char* source,                       RelativeRoot relative,                       OutputFormat output = UNCHANGED,                      bool optional = false);    ///! Call this prior to using Convert  void SetupPathConversions();    /**   * Convert the given path to an output path that is optionally   * relative based on the cache option CMAKE_USE_RELATIVE_PATHS.  The   * remote path must use forward slashes and not already be escaped   * or quoted.   */  std::string ConvertToOptionallyRelativeOutputPath(const char* remote);  // flag to determine if this project should be included in a parent project  bool GetExcludeAll()    {      return this->ExcludeFromAll;    }  void SetExcludeAll(bool b)    {      this->ExcludeFromAll = b;    }    ///! set/get the parent generator   cmLocalGenerator* GetParent(){return this->Parent;}  void SetParent(cmLocalGenerator* g) { this->Parent = g; g->AddChild(this); }  ///! set/get the children  void AddChild(cmLocalGenerator* g) { this->Children.push_back(g); }  std::vector<cmLocalGenerator*>& GetChildren() { return this->Children; };      void AddLanguageFlags(std::string& flags, const char* lang,                        const char* config);  void AddSharedFlags(std::string& flags, const char* lang, bool shared);  void AddConfigVariableFlags(std::string& flags, const char* var,                              const char* config);  void AppendFlags(std::string& flags, const char* newFlags);  ///! Get the include flags for the current makefile and language  const char* GetIncludeFlags(const char* lang);   /** Translate a dependency as given in CMake code to the name to      appear in a generated build file.  If the given name is that of      a CMake target it will be transformed to the real output      location of that target for the given configuration.  If the      given name is the full path to a file it will be returned.      Otherwise the name is treated as a relative path with respect to      the source directory of this generator.  This should only be      used for dependencies of custom commands.  */  std::string GetRealDependency(const char* name, const char* config);  ///! for existing files convert to output path and short path if spaces  std::string ConvertToOutputForExisting(const char* p);    /** Called from command-line hook to check dependencies.  */  virtual void CheckDependencies(cmMakefile* /* mf */,                                  bool /* verbose */,                                 bool /* clear */) {};    /** Called from command-line hook to scan dependencies.  */  virtual bool ScanDependencies(const char* /* tgtInfo */) { return true; }  /** Compute the list of link libraries and directories for the given      target and configuration.  */  void ComputeLinkInformation(cmTarget& target, const char* config,                              std::vector<cmStdString>& outLibs,                              std::vector<cmStdString>& outDirs,                              std::vector<cmStdString>* fullPathLibs=0);  /** Get the include flags for the current makefile and language.  */  void GetIncludeDirectories(std::vector<std::string>& dirs);  /** Compute the language used to compile the given source file.  */  const char* GetSourceFileLanguage(const cmSourceFile& source);  // Create a struct to hold the varibles passed into  // ExpandRuleVariables  struct RuleVariables  {    RuleVariables()      {        memset(this, 0,  sizeof(*this));      }    const char* TargetPDB;    const char* Language;    const char* Objects;    const char* Target;    const char* LinkLibraries;    const char* Source;    const char* AssemblySource;    const char* PreprocessedSource;    const char* Object;    const char* ObjectDir;    const char* Flags;    const char* ObjectsQuoted;    const char* TargetSOName;    const char* TargetInstallNameDir;    const char* LinkFlags;    const char* LanguageCompileFlags;  };protected:  /** Escape the given string to be used as a command line argument in      the native build system shell.  */  std::string EscapeForShell(const char* str);  /** Construct a comment for a custom command.  */  std::string ConstructComment(const cmCustomCommand& cc,                               const char* default_comment = "");  /** Fill out these strings for the given target.  Libraries to link,   *  flags, and linkflags. */  void GetTargetFlags(std::string& linkLibs,                       std::string& flags,                      std::string& linkFlags,                      cmTarget&target);    ///! put all the libraries for a target on into the given stream  virtual void OutputLinkLibraries(std::ostream&, cmTarget&, bool relink);  // Expand rule variables in CMake of the type found in language rules  void ExpandRuleVariables(std::string& string,                           const RuleVariables& replaceValues);  // Expand rule variables in a single string  std::string ExpandRuleVariable(std::string const& variable,                                 const RuleVariables& replaceValues);    /** Convert a target to a utility target for unsupported    *  languages of a generator */  void AddBuildTargetRule(const char* llang, cmTarget& target);  ///! add a custom command to build a .o file that is part of a target   void AddCustomCommandToCreateObject(const char* ofname,                                       const char* lang,                                       cmSourceFile& source,                                      cmTarget& target);  // Create Custom Targets and commands for unsupported languages  // The set passed in should contain the languages supported by the  // generator directly.  Any targets containing files that are not  // of the types listed will be compiled as custom commands and added  // to a custom target.  void CreateCustomTargetsAndCommands(std::set<cmStdString> const&);  // Handle old-style install rules stored in the targets.  void GenerateTargetInstallRules(    std::ostream& os, const char* config,    std::vector<std::string> const& configurationTypes);  // Compute object file names.  std::string GetObjectFileNameWithoutTarget(const cmSourceFile& source);  std::string& CreateSafeUniqueObjectFileName(const char* sin);  cmMakefile *Makefile;  cmGlobalGenerator *GlobalGenerator;  // members used for relative path function ConvertToMakefilePath  std::string RelativePathToSourceDir;  std::string RelativePathToBinaryDir;  std::vector<std::string> HomeDirectoryComponents;  std::vector<std::string> StartDirectoryComponents;  std::vector<std::string> HomeOutputDirectoryComponents;  std::vector<std::string> StartOutputDirectoryComponents;  bool ExcludeFromAll;  cmLocalGenerator* Parent;  std::vector<cmLocalGenerator*> Children;  std::map<cmStdString, cmStdString> LanguageToIncludeFlags;  std::map<cmStdString, cmStdString> UniqueObjectNamesMap;  bool WindowsShell;  bool ForceUnixPath;  bool UseRelativePaths;  bool IgnoreLibPrefix;  bool Configured;  bool EmitUniversalBinaryFlags;  // Hack for ExpandRuleVariable until object-oriented version is  // committed.  std::string TargetImplib;};#endif
 |