summaryrefslogtreecommitdiffstats
path: root/Source/cmVisualStudio10TargetGenerator.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-09-07 14:12:18 (GMT)
committerBrad King <brad.king@kitware.com>2009-09-07 14:12:18 (GMT)
commit4e16813f63bae65dd3eeec0a326e9a4926aff1c5 (patch)
tree27eb0f6207480c3b6bccb335bcf4d1be0df2ceca /Source/cmVisualStudio10TargetGenerator.cxx
parent4224513ccee04d540e89db5cf1ca531b6ef8e0e5 (diff)
downloadCMake-4e16813f63bae65dd3eeec0a326e9a4926aff1c5.zip
CMake-4e16813f63bae65dd3eeec0a326e9a4926aff1c5.tar.gz
CMake-4e16813f63bae65dd3eeec0a326e9a4926aff1c5.tar.bz2
Put custom commands in topological order for VS 10
Visual Studio 10 uses MSBuild to drive the build. Custom commands appear in MSBuild files inside CustomBuild elements, which appear inside ItemGroup elements. The Outputs and AdditionalInputs elements of each CustomBuild element are evaluated according to timestamps on disk. MSBuild does not use inputs/outputs to order CustomBuild steps within a single ItemGroup or across multiple ItemGroup elements. Instead we must put only unrelated CustomBuild elements in a single ItemGroup and order the item groups from top to bottom using a topological order of the custom command dependency graph. This fixes CustomCommand and ExternalProject test failures, so we remove the expectation of these failures.
Diffstat (limited to 'Source/cmVisualStudio10TargetGenerator.cxx')
-rw-r--r--Source/cmVisualStudio10TargetGenerator.cxx34
1 files changed, 27 insertions, 7 deletions
diff --git a/Source/cmVisualStudio10TargetGenerator.cxx b/Source/cmVisualStudio10TargetGenerator.cxx
index e8aaf61..a335043 100644
--- a/Source/cmVisualStudio10TargetGenerator.cxx
+++ b/Source/cmVisualStudio10TargetGenerator.cxx
@@ -247,18 +247,38 @@ void cmVisualStudio10TargetGenerator::WriteProjectConfigurationValues()
}
void cmVisualStudio10TargetGenerator::WriteCustomCommands()
-{
- this->WriteString("<ItemGroup>\n", 1);
- std::vector<cmSourceFile*>const & sources = this->Target->GetSourceFiles();
+{
+ this->SourcesVisited.clear();
+ std::vector<cmSourceFile*> const& sources = this->Target->GetSourceFiles();
for(std::vector<cmSourceFile*>::const_iterator source = sources.begin();
source != sources.end(); ++source)
{
- if(cmCustomCommand const* command = (*source)->GetCustomCommand())
+ cmSourceFile* sf = *source;
+ this->WriteCustomCommand(sf);
+ }
+}
+
+//----------------------------------------------------------------------------
+void cmVisualStudio10TargetGenerator::WriteCustomCommand(cmSourceFile* sf)
+{
+ if(this->SourcesVisited.insert(sf).second)
+ {
+ if(std::vector<cmSourceFile*> const* depends =
+ this->Target->GetSourceDepends(sf))
{
- this->WriteCustomRule(*source, *command);
+ for(std::vector<cmSourceFile*>::const_iterator di = depends->begin();
+ di != depends->end(); ++di)
+ {
+ this->WriteCustomCommand(*di);
+ }
}
- }
- this->WriteString("</ItemGroup>\n", 1);
+ if(cmCustomCommand const* command = sf->GetCustomCommand())
+ {
+ this->WriteString("<ItemGroup>\n", 1);
+ this->WriteCustomRule(sf, *command);
+ this->WriteString("</ItemGroup>\n", 1);
+ }
+ }
}
void