ENH: Generate a central list of target directories
This generalizes the previous CMakeFiles/LabelFiles.txt created at the top of the build tree to a CMakeFiles/TargetDirectories.txt file. It lists the target support directories for all targets in the project. Labels can still be loaded by looking for Labels.txt files in each target directory.
This commit is contained in:
parent
b9323d2dd6
commit
a86e81c358
|
@ -1749,9 +1749,9 @@ void cmCTestCoverageHandler::LoadLabels()
|
||||||
{
|
{
|
||||||
std::string fileList = this->CTest->GetBinaryDir();
|
std::string fileList = this->CTest->GetBinaryDir();
|
||||||
fileList += cmake::GetCMakeFilesDirectory();
|
fileList += cmake::GetCMakeFilesDirectory();
|
||||||
fileList += "/LabelFiles.txt";
|
fileList += "/TargetDirectories.txt";
|
||||||
cmCTestLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
cmCTestLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
||||||
" label file list [" << fileList << "]\n");
|
" target directory list [" << fileList << "]\n");
|
||||||
std::ifstream finList(fileList.c_str());
|
std::ifstream finList(fileList.c_str());
|
||||||
std::string line;
|
std::string line;
|
||||||
while(cmSystemTools::GetLineFromStream(finList, line))
|
while(cmSystemTools::GetLineFromStream(finList, line))
|
||||||
|
@ -1761,11 +1761,18 @@ void cmCTestCoverageHandler::LoadLabels()
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void cmCTestCoverageHandler::LoadLabels(const char* fname)
|
void cmCTestCoverageHandler::LoadLabels(const char* dir)
|
||||||
{
|
{
|
||||||
|
std::string fname = dir;
|
||||||
|
fname += "/Labels.txt";
|
||||||
|
std::ifstream fin(fname.c_str());
|
||||||
|
if(!fin)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cmCTestLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
cmCTestLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
||||||
" loading labels from [" << fname << "]\n");
|
" loading labels from [" << fname << "]\n");
|
||||||
std::ifstream fin(fname);
|
|
||||||
bool inTarget = true;
|
bool inTarget = true;
|
||||||
std::string source;
|
std::string source;
|
||||||
std::string line;
|
std::string line;
|
||||||
|
|
|
@ -152,9 +152,9 @@ private:
|
||||||
std::vector<std::string> Labels;
|
std::vector<std::string> Labels;
|
||||||
int GetLabelId(std::string const& label);
|
int GetLabelId(std::string const& label);
|
||||||
|
|
||||||
// Load reading and writing methods.
|
// Label reading and writing methods.
|
||||||
void LoadLabels();
|
void LoadLabels();
|
||||||
void LoadLabels(const char* fname);
|
void LoadLabels(const char* dir);
|
||||||
void WriteXMLLabels(std::ofstream& os, std::string const& source);
|
void WriteXMLLabels(std::ofstream& os, std::string const& source);
|
||||||
|
|
||||||
// Label-based filtering.
|
// Label-based filtering.
|
||||||
|
|
|
@ -901,7 +901,7 @@ void cmGlobalGenerator::Generate()
|
||||||
// Update rule hashes.
|
// Update rule hashes.
|
||||||
this->CheckRuleHashes();
|
this->CheckRuleHashes();
|
||||||
|
|
||||||
this->WriteTargetLabels();
|
this->WriteSummary();
|
||||||
|
|
||||||
if (this->ExtraGenerator != 0)
|
if (this->ExtraGenerator != 0)
|
||||||
{
|
{
|
||||||
|
@ -2137,44 +2137,32 @@ void cmGlobalGenerator::CheckRuleHashes()
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
void cmGlobalGenerator::WriteTargetLabels()
|
void cmGlobalGenerator::WriteSummary()
|
||||||
{
|
{
|
||||||
cmMakefile* mf = this->LocalGenerators[0]->GetMakefile();
|
cmMakefile* mf = this->LocalGenerators[0]->GetMakefile();
|
||||||
|
|
||||||
// Record generated per-target label files in a central location.
|
// Record all target directories in a central location.
|
||||||
std::string fname = mf->GetHomeOutputDirectory();
|
std::string fname = mf->GetHomeOutputDirectory();
|
||||||
fname += cmake::GetCMakeFilesDirectory();
|
fname += cmake::GetCMakeFilesDirectory();
|
||||||
fname += "/LabelFiles.txt";
|
fname += "/TargetDirectories.txt";
|
||||||
bool opened = false;
|
cmGeneratedFileStream fout(fname.c_str());
|
||||||
cmGeneratedFileStream fout;
|
|
||||||
|
|
||||||
// Generate a label file for each target.
|
// Generate summary information files for each target.
|
||||||
std::string file;
|
std::string dir;
|
||||||
for(std::map<cmStdString,cmTarget *>::const_iterator ti =
|
for(std::map<cmStdString,cmTarget *>::const_iterator ti =
|
||||||
this->TotalTargets.begin(); ti != this->TotalTargets.end(); ++ti)
|
this->TotalTargets.begin(); ti != this->TotalTargets.end(); ++ti)
|
||||||
{
|
{
|
||||||
if(this->WriteTargetLabels(ti->second, file))
|
this->WriteSummary(ti->second);
|
||||||
{
|
fout << ti->second->GetSupportDirectory() << "\n";
|
||||||
if(!opened)
|
|
||||||
{
|
|
||||||
fout.Open(fname.c_str());
|
|
||||||
opened = true;
|
|
||||||
}
|
|
||||||
fout << file << "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(!opened)
|
|
||||||
{
|
|
||||||
cmSystemTools::RemoveFile(fname.c_str());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
bool cmGlobalGenerator::WriteTargetLabels(cmTarget* target, std::string& file)
|
void cmGlobalGenerator::WriteSummary(cmTarget* target)
|
||||||
{
|
{
|
||||||
// Place the labels file in a per-target support directory.
|
// Place the labels file in a per-target support directory.
|
||||||
std::string dir = target->GetSupportDirectory();
|
std::string dir = target->GetSupportDirectory();
|
||||||
file = dir;
|
std::string file = dir;
|
||||||
file += "/Labels.txt";
|
file += "/Labels.txt";
|
||||||
|
|
||||||
// Check whether labels are enabled for this target.
|
// Check whether labels are enabled for this target.
|
||||||
|
@ -2216,11 +2204,9 @@ bool cmGlobalGenerator::WriteTargetLabels(cmTarget* target, std::string& file)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cmSystemTools::RemoveFile(file.c_str());
|
cmSystemTools::RemoveFile(file.c_str());
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -336,8 +336,8 @@ private:
|
||||||
std::map<cmStdString, RuleHash> RuleHashes;
|
std::map<cmStdString, RuleHash> RuleHashes;
|
||||||
void CheckRuleHashes();
|
void CheckRuleHashes();
|
||||||
|
|
||||||
void WriteTargetLabels();
|
void WriteSummary();
|
||||||
bool WriteTargetLabels(cmTarget* target, std::string& file);
|
void WriteSummary(cmTarget* target);
|
||||||
|
|
||||||
cmExternalMakefileProjectGenerator* ExtraGenerator;
|
cmExternalMakefileProjectGenerator* ExtraGenerator;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue