diff options
author | Ken Martin <ken.martin@kitware.com> | 2005-06-01 17:37:49 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2005-06-01 17:37:49 (GMT) |
commit | 46e5b9afe2e155aebc4eac0fed80ef98b23a0f7d (patch) | |
tree | 63712ca0454c157a123e475e95bc9eee57d8e343 | |
parent | 0f8282fab1bd7a52d33914cdf73cb80113b49f7a (diff) | |
download | CMake-46e5b9afe2e155aebc4eac0fed80ef98b23a0f7d.zip CMake-46e5b9afe2e155aebc4eac0fed80ef98b23a0f7d.tar.gz CMake-46e5b9afe2e155aebc4eac0fed80ef98b23a0f7d.tar.bz2 |
ENH: minor perf improvement
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator3.cxx | 21 | ||||
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator3.h | 11 |
2 files changed, 26 insertions, 6 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx index f6a4816..b6541bd 100644 --- a/Source/cmLocalUnixMakefileGenerator3.cxx +++ b/Source/cmLocalUnixMakefileGenerator3.cxx @@ -55,6 +55,13 @@ cmLocalUnixMakefileGenerator3::~cmLocalUnixMakefileGenerator3() } //---------------------------------------------------------------------------- +void cmLocalUnixMakefileGenerator3::Configure() +{ + this->ComputeHomeRelativeOutputPath(); + this->cmLocalGenerator::Configure(); +} + +//---------------------------------------------------------------------------- void cmLocalUnixMakefileGenerator3::Generate() { // Setup our configuration variables for this directory. @@ -259,17 +266,21 @@ void cmLocalUnixMakefileGenerator3::WriteDisclaimer(std::ostream& os) << cmMakefile::GetMinorVersion() << "\n\n"; } -std::string cmLocalUnixMakefileGenerator3::GetHomeRelativeOutputPath() +void cmLocalUnixMakefileGenerator3::ComputeHomeRelativeOutputPath() { // Include the rule file for each object. - std::string relPath = + m_HomeRelativeOutputPath = cmSystemTools::RelativePath(m_Makefile->GetHomeOutputDirectory(), m_Makefile->GetStartOutputDirectory()); - if (relPath.size()) + if (m_HomeRelativeOutputPath.size()) { - relPath += "/"; + m_HomeRelativeOutputPath += "/"; } - return relPath; +} + +const std::string &cmLocalUnixMakefileGenerator3::GetHomeRelativeOutputPath() +{ + return m_HomeRelativeOutputPath; } //---------------------------------------------------------------------------- diff --git a/Source/cmLocalUnixMakefileGenerator3.h b/Source/cmLocalUnixMakefileGenerator3.h index d107b25..ffeb0b8 100644 --- a/Source/cmLocalUnixMakefileGenerator3.h +++ b/Source/cmLocalUnixMakefileGenerator3.h @@ -43,12 +43,18 @@ public: */ virtual void Generate(); + /** + * Process the CMakeLists files for this directory to fill in the + * m_Makefile ivar + */ + virtual void Configure(); + /** creates the common disclainer text at the top of each makefile */ void WriteDisclaimer(std::ostream& os); // this returns the relative path between the HomeOutputDirectory and this // local generators StartOutputDirectory - std::string GetHomeRelativeOutputPath(); + const std::string &GetHomeRelativeOutputPath(); // Write out a make rule void WriteMakeRule(std::ostream& os, @@ -312,6 +318,7 @@ protected: std::string CreateMakeVariable(const char* sin, const char* s2in); //========================================================================== + void ComputeHomeRelativeOutputPath(); private: std::map<cmStdString, IntegrityCheckSet> m_CheckDependFiles; @@ -332,6 +339,8 @@ private: // Flag for whether echo command needs quotes. bool m_EchoNeedsQuote; + std::string m_HomeRelativeOutputPath; + // Set of object file names that will be built in this directory. std::set<cmStdString> m_ObjectFiles; }; |