diff options
Diffstat (limited to 'Source/cmMakefile.cxx')
-rw-r--r-- | Source/cmMakefile.cxx | 83 |
1 files changed, 38 insertions, 45 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index 9be764f..0cfe265 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -155,6 +155,11 @@ void cmMakefile::Print() const this->PrintStringVector("m_LinkDirectories", m_LinkDirectories); this->PrintStringVector("m_Utilities", m_Utilities); this->PrintStringVector("m_UtilityDirectories", m_UtilityDirectories); + for( std::vector<cmSourceGroup>::const_iterator i = m_SourceGroups.begin(); + i != m_SourceGroups.end(); ++i) + { + i->Print(); + } } // Parse the given CMakeLists.txt file into a list of classes. @@ -231,63 +236,51 @@ bool cmMakefile::ReadListFile(const char* filename, const char* external) std::vector<std::string> arguments; while ( fin ) { - // add this list file to the list of dependencies - m_ListFiles.push_back( filenametoread); + // add this list file to the list of dependencies + m_ListFiles.push_back( filenametoread); if(cmSystemTools::ParseFunction(fin, name, arguments) && !this->IsFunctionBlocked(name.c_str(),arguments)) { - // Special command that needs to be removed when - // ADD_COMMAND is implemented - if(name == "VERBATIM") - { - if (!inheriting) - { - m_MakeVerbatim = arguments; - } - } - else + RegisteredCommandsMap::iterator pos = m_Commands.find(name); + if(pos != m_Commands.end()) { - RegisteredCommandsMap::iterator pos = m_Commands.find(name); - if(pos != m_Commands.end()) + cmCommand* rm = (*pos).second; + cmCommand* usedCommand = rm->Clone(); + usedCommand->SetMakefile(this); + bool keepCommand = false; + if(usedCommand->GetEnabled()) { - cmCommand* rm = (*pos).second; - cmCommand* usedCommand = rm->Clone(); - usedCommand->SetMakefile(this); - bool keepCommand = false; - if(usedCommand->GetEnabled()) + // if not running in inherit mode or + // if the command is inherited then Invoke it. + if(!inheriting || usedCommand->IsInherited()) { - // if not running in inherit mode or - // if the command is inherited then Invoke it. - if(!inheriting || usedCommand->IsInherited()) + if(!usedCommand->Invoke(arguments)) { - if(!usedCommand->Invoke(arguments)) - { - cmSystemTools::Error(usedCommand->GetName(), - ": Error : \n", - usedCommand->GetError(), - m_cmCurrentDirectory.c_str()); - } - else - { - // use the command - keepCommand = true; - m_UsedCommands.push_back(usedCommand); - } + cmSystemTools::Error(usedCommand->GetName(), + ": Error : \n", + usedCommand->GetError(), + m_cmCurrentDirectory.c_str()); + } + else + { + // use the command + keepCommand = true; + m_UsedCommands.push_back(usedCommand); } - } - // if the Cloned command was not used - // then delete it - if(!keepCommand) - { - delete usedCommand; } } - else + // if the Cloned command was not used + // then delete it + if(!keepCommand) { - cmSystemTools::Error("unknown CMake command ", name.c_str()); + delete usedCommand; } } + else + { + cmSystemTools::Error("unknown CMake command ", name.c_str(), filename); + } } } @@ -663,11 +656,11 @@ void cmMakefile::RemoveVariablesInString(std::string& source) const cmRegularExpression var2("(@[A-Za-z_0-9]*@)"); while (var.find(source)) { - source.erase(var.start(),var.end()); + source.erase(var.start(),var.end() - var.start()); } while (var2.find(source)) { - source.erase(var2.start(),var2.end()); + source.erase(var2.start(),var2.end() - var2.start()); } } |