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;
|
|
|
|
|
|
|
|
/** \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();
|
|
|
|
|
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);
|
2003-12-22 23:16:46 +03:00
|
|
|
std::string ConvertToRelativeOutputPath(const char* p);
|
2002-08-31 00:00:35 +04:00
|
|
|
protected:
|
|
|
|
bool m_FromTheTop;
|
|
|
|
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;
|
|
|
|
std::string m_CurrentOutputDirectory;
|
|
|
|
std::string m_HomeOutputDirectory;
|
|
|
|
std::string m_HomeDirectory;
|
|
|
|
std::string m_HomeOutputDirectoryNoSlash;
|
|
|
|
|
2002-08-31 00:00:35 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|