2005-05-05 20:45:53 +04:00
|
|
|
/*=========================================================================
|
|
|
|
|
|
|
|
Program: CMake - Cross-Platform Makefile Generator3
|
|
|
|
Module: $RCSfile$
|
|
|
|
Language: C++
|
|
|
|
Date: $Date$
|
|
|
|
Version: $Revision$
|
|
|
|
|
|
|
|
Copyright (c) 2005 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 cmGlobalUnixMakefileGenerator3_h
|
|
|
|
#define cmGlobalUnixMakefileGenerator3_h
|
|
|
|
|
|
|
|
#include "cmGlobalGenerator.h"
|
|
|
|
|
2005-05-06 22:49:38 +04:00
|
|
|
class cmGeneratedFileStream;
|
|
|
|
class cmLocalUnixMakefileGenerator3;
|
|
|
|
|
2005-05-05 20:45:53 +04:00
|
|
|
/** \class cmGlobalUnixMakefileGenerator3
|
|
|
|
* \brief Write a Unix makefiles.
|
|
|
|
*
|
|
|
|
* cmGlobalUnixMakefileGenerator3 manages UNIX build process for a tree
|
2005-05-31 19:46:49 +04:00
|
|
|
|
|
|
|
|
|
|
|
The basic approach of this generator is to produce Makefiles that will all
|
|
|
|
be run with the current working directory set to the Home Output
|
|
|
|
directory. The one exception to this is the subdirectory Makefiles which are
|
|
|
|
created as a convenience and just cd up to the Home Output directory and
|
|
|
|
invoke the main Makefiles.
|
|
|
|
|
|
|
|
The make process starts with Makefile. Makefile should only contain the
|
|
|
|
targets the user is likely to invoke directly from a make command line. No
|
|
|
|
internal targets should be in this file. Makefile2 contains the internal
|
|
|
|
targets that are required to make the process work.
|
|
|
|
|
|
|
|
Makefile2 in turn will recursively make targets in the correct order. Each
|
|
|
|
target has its own directory <target>.dir and its own makefile build.make in
|
|
|
|
that directory. Also in that directory is a couple makefiles per source file
|
|
|
|
used by the target. Typically these are named source.obj.build.make and
|
|
|
|
source.obj.build.depend.make. The source.obj.build.make contains the rules
|
|
|
|
for building, cleaning, and computing dependencies for the given source
|
|
|
|
file. The build.depend.make contains additional dependencies that were
|
|
|
|
computed during dependency scanning. An additional file called
|
|
|
|
source.obj.depend is used as a marker to indicate when dependencies must be
|
|
|
|
rescanned.
|
|
|
|
|
|
|
|
Rules for custom commands follow the same model as rules for source files.
|
|
|
|
|
2005-05-05 20:45:53 +04:00
|
|
|
*/
|
2005-05-31 19:46:49 +04:00
|
|
|
|
2005-05-05 20:45:53 +04:00
|
|
|
class cmGlobalUnixMakefileGenerator3 : public cmGlobalGenerator
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
cmGlobalUnixMakefileGenerator3();
|
2006-05-11 18:40:28 +04:00
|
|
|
static cmGlobalGenerator* New() {
|
|
|
|
return new cmGlobalUnixMakefileGenerator3; }
|
2005-05-05 20:45:53 +04:00
|
|
|
|
|
|
|
///! Get the name for the generator.
|
|
|
|
virtual const char* GetName() const {
|
|
|
|
return cmGlobalUnixMakefileGenerator3::GetActualName();}
|
2005-05-25 19:18:41 +04:00
|
|
|
static const char* GetActualName() {return "Unix Makefiles";}
|
2005-05-05 20:45:53 +04:00
|
|
|
|
|
|
|
/** Get the documentation entry for this generator. */
|
|
|
|
virtual void GetDocumentation(cmDocumentationEntry& entry) const;
|
|
|
|
|
|
|
|
///! Create a local generator appropriate to this Global Generator3
|
|
|
|
virtual cmLocalGenerator *CreateLocalGenerator();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Try to determine system infomation such as shared library
|
|
|
|
* extension, pthreads, byte order etc.
|
|
|
|
*/
|
2006-03-10 21:54:57 +03:00
|
|
|
virtual void EnableLanguage(std::vector<std::string>const& languages,
|
2007-06-28 17:09:26 +04:00
|
|
|
cmMakefile *, bool optional);
|
2005-05-05 20:45:53 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Generate the all required files for building this project/tree. This
|
|
|
|
* basically creates a series of LocalGenerators for each directory and
|
|
|
|
* requests that they Generate.
|
|
|
|
*/
|
|
|
|
virtual void Generate();
|
2005-07-27 17:49:37 +04:00
|
|
|
|
|
|
|
|
|
|
|
void WriteMainCMakefileLanguageRules(cmGeneratedFileStream& cmakefileStream,
|
|
|
|
std::vector<cmLocalGenerator *> &);
|
2005-05-05 20:45:53 +04:00
|
|
|
|
2005-10-20 21:40:28 +04:00
|
|
|
// write out the help rule listing the valid targets
|
|
|
|
void WriteHelpRule(std::ostream& ruleFileStream,
|
|
|
|
cmLocalUnixMakefileGenerator3 *);
|
|
|
|
|
|
|
|
// write the top lvel target rules
|
|
|
|
void WriteConvenienceRules(std::ostream& ruleFileStream,
|
|
|
|
std::set<cmStdString> &emitted);
|
|
|
|
|
2007-05-16 21:24:17 +04:00
|
|
|
/** Get the command to use for a target that has no rule. This is
|
|
|
|
used for multiple output dependencies and for cmake_force. */
|
|
|
|
std::string GetEmptyRuleHackCommand() { return this->EmptyRuleHackCommand; }
|
2006-05-02 17:56:42 +04:00
|
|
|
|
2006-12-14 22:30:41 +03:00
|
|
|
/** Get the fake dependency to use when a rule has no real commands
|
|
|
|
or dependencies. */
|
|
|
|
std::string GetEmptyRuleHackDepends() { return this->EmptyRuleHackDepends; }
|
2006-05-02 17:56:42 +04:00
|
|
|
|
|
|
|
// change the build command for speed
|
|
|
|
virtual std::string GenerateBuildCommand
|
|
|
|
(const char* makeProgram,
|
|
|
|
const char *projectName, const char* additionalOptions,
|
|
|
|
const char *targetName,
|
2006-06-01 23:51:24 +04:00
|
|
|
const char* config, bool ignoreErrors, bool fast);
|
2006-05-02 17:56:42 +04:00
|
|
|
|
2006-07-11 17:55:27 +04:00
|
|
|
// returns some progress informaiton
|
2006-08-29 20:55:11 +04:00
|
|
|
int GetTargetTotalNumberOfActions(cmTarget& target,
|
|
|
|
std::set<cmStdString> &emitted);
|
2006-07-11 17:55:27 +04:00
|
|
|
unsigned long GetNumberOfProgressActionsInAll
|
|
|
|
(cmLocalUnixMakefileGenerator3 *lg);
|
2006-05-25 18:55:24 +04:00
|
|
|
|
2007-06-06 00:35:24 +04:00
|
|
|
/**
|
2007-06-06 00:37:27 +04:00
|
|
|
* If true, the CMake variable CMAKE_VERBOSE_MAKEFILES doesn't have effect
|
2007-06-06 00:35:24 +04:00
|
|
|
* anymore. Set it to true when writing a generator where short output
|
|
|
|
* doesn't make sense, e.g. because the full output is parsed by an
|
|
|
|
* IDE/editor.
|
|
|
|
*/
|
2007-06-06 00:37:27 +04:00
|
|
|
bool GetForceVerboseMakefiles() { return this->ForceVerboseMakefiles; }
|
2007-06-06 00:35:24 +04:00
|
|
|
void SetForceVerboseMakefiles(bool enable)
|
|
|
|
{this->ForceVerboseMakefiles=enable;}
|
|
|
|
|
2005-05-05 20:45:53 +04:00
|
|
|
protected:
|
2005-05-31 19:46:49 +04:00
|
|
|
void WriteMainMakefile2();
|
2005-05-05 20:45:53 +04:00
|
|
|
void WriteMainCMakefile();
|
2007-08-03 23:44:25 +04:00
|
|
|
|
|
|
|
void WriteConvenienceRules2(std::ostream& ruleFileStream,
|
|
|
|
cmLocalUnixMakefileGenerator3*);
|
2005-05-31 19:46:49 +04:00
|
|
|
|
2006-03-02 02:54:17 +03:00
|
|
|
void WriteDirectoryRule2(std::ostream& ruleFileStream,
|
|
|
|
cmLocalUnixMakefileGenerator3* lg,
|
|
|
|
const char* pass, bool check_all,
|
|
|
|
bool check_relink);
|
|
|
|
void WriteDirectoryRules2(std::ostream& ruleFileStream,
|
|
|
|
cmLocalUnixMakefileGenerator3* lg);
|
2005-05-18 21:46:00 +04:00
|
|
|
|
|
|
|
void AppendGlobalTargetDepends(std::vector<std::string>& depends,
|
2005-06-22 17:06:46 +04:00
|
|
|
cmTarget& target);
|
2005-05-31 19:46:49 +04:00
|
|
|
void AppendAnyGlobalDepend(std::vector<std::string>& depends,
|
2005-10-10 19:49:17 +04:00
|
|
|
const char* name,
|
|
|
|
cmTarget &target);
|
2005-05-18 21:46:00 +04:00
|
|
|
|
2005-05-24 19:17:30 +04:00
|
|
|
// does this generator need a requires step for any of its targets
|
2007-08-03 17:39:32 +04:00
|
|
|
bool NeedRequiresStep(cmTarget const&);
|
2005-05-06 22:49:38 +04:00
|
|
|
|
2006-02-23 21:37:35 +03:00
|
|
|
// Setup target names
|
2006-03-01 16:28:39 +03:00
|
|
|
virtual const char* GetAllTargetName() { return "all"; }
|
2006-02-23 21:37:35 +03:00
|
|
|
virtual const char* GetInstallTargetName() { return "install"; }
|
2006-08-29 18:03:47 +04:00
|
|
|
virtual const char* GetInstallLocalTargetName() { return "install/local"; }
|
2007-05-18 21:43:39 +04:00
|
|
|
virtual const char* GetInstallStripTargetName() { return "install/strip"; }
|
2006-02-23 21:37:35 +03:00
|
|
|
virtual const char* GetPreinstallTargetName() { return "preinstall"; }
|
|
|
|
virtual const char* GetTestTargetName() { return "test"; }
|
|
|
|
virtual const char* GetPackageTargetName() { return "package"; }
|
2006-04-17 23:26:54 +04:00
|
|
|
virtual const char* GetPackageSourceTargetName(){ return "package_source"; }
|
2006-02-23 21:37:35 +03:00
|
|
|
virtual const char* GetEditCacheTargetName() { return "edit_cache"; }
|
|
|
|
virtual const char* GetRebuildCacheTargetName() { return "rebuild_cache"; }
|
2007-11-25 15:34:53 +03:00
|
|
|
virtual const char* GetCleanTargetName() { return "clean"; }
|
2006-02-23 21:37:35 +03:00
|
|
|
|
2006-02-17 02:50:16 +03:00
|
|
|
// Some make programs (Borland) do not keep a rule if there are no
|
|
|
|
// dependencies or commands. This is a problem for creating rules
|
|
|
|
// that might not do anything but might have other dependencies
|
|
|
|
// added later. If non-empty this variable holds a fake dependency
|
|
|
|
// that can be added.
|
2006-03-15 19:02:08 +03:00
|
|
|
std::string EmptyRuleHackDepends;
|
2006-04-11 19:06:19 +04:00
|
|
|
|
2007-05-16 21:24:17 +04:00
|
|
|
// Some make programs (Watcom) do not like rules with no commands.
|
|
|
|
// If non-empty this variable holds a bogus command that may be put
|
|
|
|
// in the rule to satisfy the make program.
|
|
|
|
std::string EmptyRuleHackCommand;
|
2006-04-13 18:15:48 +04:00
|
|
|
|
2006-05-23 17:11:46 +04:00
|
|
|
std::map<cmStdString, int > TargetSourceFileCount;
|
2007-06-06 00:35:24 +04:00
|
|
|
bool ForceVerboseMakefiles;
|
2007-12-22 21:08:26 +03:00
|
|
|
|
|
|
|
bool AllowTargetDepends(cmTarget const* depender,
|
|
|
|
cmTarget const* dependee);
|
|
|
|
bool FindDependency(cmTarget const* goal, cmTarget const* current,
|
|
|
|
std::vector<cmTarget const*>& steps);
|
|
|
|
class TargetDependSet: public std::set<cmTarget const*> {};
|
|
|
|
typedef std::map<cmTarget const*, TargetDependSet> TargetDependMap;
|
|
|
|
TargetDependMap TargetDependencies;
|
2005-05-05 20:45:53 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|