2002-08-31 00:00:35 +04:00
|
|
|
/*=========================================================================
|
|
|
|
|
2002-10-24 02:03:27 +04:00
|
|
|
Program: CMake - Cross-Platform Makefile Generator
|
2002-08-31 00:00:35 +04:00
|
|
|
Module: $RCSfile$
|
|
|
|
Language: C++
|
|
|
|
Date: $Date$
|
|
|
|
Version: $Revision$
|
|
|
|
|
2002-10-24 02:03:27 +04:00
|
|
|
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
|
|
|
|
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
|
2002-08-31 00:00:35 +04:00
|
|
|
|
|
|
|
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;
|
2004-01-26 03:25:26 +03:00
|
|
|
class cmTarget;
|
2004-10-21 22:34:02 +04:00
|
|
|
class cmSourceFile;
|
|
|
|
|
2002-08-31 00:00:35 +04:00
|
|
|
|
|
|
|
/** \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();
|
2002-09-05 17:04:55 +04:00
|
|
|
virtual ~cmLocalGenerator();
|
2002-08-31 00:00:35 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Generate the makefile for this directory. fromTheTop indicates if this
|
|
|
|
* is being invoked as part of a global Generate or specific to this
|
|
|
|
* directory. The difference is that when done from the Top we might skip
|
|
|
|
* some steps to save time, such as dependency generation for the
|
|
|
|
* makefiles. This is done by a direct invocation from make.
|
|
|
|
*/
|
2002-09-08 05:22:03 +04:00
|
|
|
virtual void Generate(bool /* fromTheTop */) {};
|
2002-08-31 00:00:35 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Process the CMakeLists files for this directory to fill in the
|
|
|
|
* m_Makefile ivar
|
|
|
|
*/
|
|
|
|
virtual void Configure();
|
|
|
|
|
2002-09-15 16:54:16 +04:00
|
|
|
/**
|
|
|
|
* Perform any final calculations prior to generation
|
|
|
|
*/
|
|
|
|
virtual void ConfigureFinalPass();
|
|
|
|
|
2004-01-26 03:25:26 +03:00
|
|
|
/**
|
|
|
|
* Generate the install rules files in this directory.
|
|
|
|
*/
|
|
|
|
virtual void GenerateInstallRules();
|
|
|
|
|
2002-08-31 00:00:35 +04:00
|
|
|
///! Get the makefile for this generator
|
|
|
|
cmMakefile *GetMakefile() {
|
|
|
|
return this->m_Makefile; };
|
|
|
|
|
|
|
|
///! Get the GlobalGenerator this is associated with
|
|
|
|
cmGlobalGenerator *GetGlobalGenerator() {
|
|
|
|
return m_GlobalGenerator; };
|
|
|
|
|
|
|
|
///! Set the Global Generator, done on creation by the GlobalGenerator
|
2002-09-04 23:24:49 +04:00
|
|
|
void SetGlobalGenerator(cmGlobalGenerator *gg);
|
2004-01-26 03:25:26 +03:00
|
|
|
|
|
|
|
/** Get the full name of the target's file, without path. */
|
|
|
|
std::string GetFullTargetName(const char* n, const cmTarget& t);
|
|
|
|
|
2005-02-25 00:04:54 +03:00
|
|
|
/**
|
|
|
|
* Convert the given remote path to a relative path with respect to
|
|
|
|
* this generator's output directory. The remote path must use
|
|
|
|
* forward slashes and not already be escaped or quoted.
|
|
|
|
*/
|
|
|
|
std::string ConvertToRelativePath(const char* remote);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert to an output path that is relative to the current output
|
|
|
|
* directory. The remote path must use forward slashes and not
|
|
|
|
* already be escaped or quoted.
|
|
|
|
*/
|
|
|
|
std::string ConvertToRelativeOutputPath(const char* remote);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls ConvertToRelativePath conditionally on the cache option
|
|
|
|
* CMAKE_USE_RELATIVE_PATHS. The remote path must use forward
|
|
|
|
* slashes and not already be escaped or quoted.
|
|
|
|
*/
|
|
|
|
std::string ConvertToOptionallyRelativePath(const char* remote);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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);
|
|
|
|
|
2004-03-10 00:28:44 +03:00
|
|
|
// flag to determine if this project should be included in a parent project
|
|
|
|
bool GetExcludeAll()
|
|
|
|
{
|
|
|
|
return m_ExcludeFromAll;
|
|
|
|
}
|
|
|
|
void SetExcludeAll(bool b)
|
|
|
|
{
|
|
|
|
m_ExcludeFromAll = b;
|
|
|
|
}
|
|
|
|
|
|
|
|
///! set/get the parent generator
|
|
|
|
cmLocalGenerator* GetParent(){return m_Parent;}
|
|
|
|
void SetParent(cmLocalGenerator* g) { m_Parent = g;}
|
2004-06-28 22:40:17 +04:00
|
|
|
|
2005-02-02 21:19:57 +03:00
|
|
|
void AddLanguageFlags(std::string& flags, const char* lang);
|
|
|
|
void AddSharedFlags(std::string& flags, const char* lang, bool shared);
|
|
|
|
void AddConfigVariableFlags(std::string& flags, const char* var);
|
|
|
|
void AppendFlags(std::string& flags, const char* newFlags);
|
2005-02-04 01:42:55 +03:00
|
|
|
///! Get the include flags for the current makefile and language
|
|
|
|
const char* GetIncludeFlags(const char* lang);
|
2005-02-02 21:19:57 +03:00
|
|
|
|
2005-02-15 00:46:32 +03:00
|
|
|
///! for existing files convert to output path and short path if spaces
|
|
|
|
std::string ConvertToOutputForExisting(const char* p);
|
|
|
|
|
2005-02-03 01:16:07 +03:00
|
|
|
protected:
|
2005-02-22 18:32:44 +03:00
|
|
|
/** Construct a script from the given list of command lines. */
|
|
|
|
std::string ConstructScript(const cmCustomCommandLines& commandLines,
|
|
|
|
const char* newline = "\n");
|
2005-02-03 01:16:07 +03:00
|
|
|
|
2004-10-21 22:34:02 +04:00
|
|
|
///! 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&, const char* name, const cmTarget &);
|
|
|
|
|
2004-10-26 18:15:49 +04:00
|
|
|
|
|
|
|
/** Get the include flags for the current makefile and language. */
|
|
|
|
void GetIncludeDirectories(std::vector<std::string>& dirs);
|
|
|
|
|
2004-10-21 22:34:02 +04:00
|
|
|
// Expand rule variables in CMake of the type found in language rules
|
|
|
|
void ExpandRuleVariables(std::string& string,
|
|
|
|
const char* language,
|
|
|
|
const char* objects=0,
|
|
|
|
const char* target=0,
|
|
|
|
const char* linkLibs=0,
|
|
|
|
const char* source=0,
|
|
|
|
const char* object =0,
|
|
|
|
const char* flags = 0,
|
|
|
|
const char* objectsquoted = 0,
|
|
|
|
const char* targetBase = 0,
|
|
|
|
const char* targetSOName = 0,
|
|
|
|
const char* linkFlags = 0);
|
|
|
|
///! 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&);
|
2004-01-27 20:37:30 +03:00
|
|
|
virtual void AddInstallRule(std::ostream& fout, const char* dest, int type,
|
2004-06-28 22:40:17 +04:00
|
|
|
const char* files, bool optional = false, const char* properties = 0);
|
2004-01-26 03:25:26 +03:00
|
|
|
|
2002-08-31 00:00:35 +04:00
|
|
|
cmMakefile *m_Makefile;
|
|
|
|
cmGlobalGenerator *m_GlobalGenerator;
|
2003-12-22 23:16:46 +03:00
|
|
|
// members used for relative path function ConvertToMakefilePath
|
|
|
|
std::string m_RelativePathToSourceDir;
|
|
|
|
std::string m_RelativePathToBinaryDir;
|
2005-02-25 00:04:54 +03:00
|
|
|
std::vector<std::string> m_CurrentOutputDirectoryComponents;
|
2004-03-10 00:28:44 +03:00
|
|
|
bool m_ExcludeFromAll;
|
|
|
|
cmLocalGenerator* m_Parent;
|
2004-10-21 22:34:02 +04:00
|
|
|
std::map<cmStdString, cmStdString> m_LanguageToIncludeFlags;
|
|
|
|
bool m_WindowsShell;
|
|
|
|
bool m_UseRelativePaths;
|
|
|
|
bool m_IgnoreLibPrefix;
|
2002-08-31 00:00:35 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|