I need a set of tasks that need to be executed exactly once for the entire solution. This will run tasks that will modify each project to run a separate set of tasks for each pr
An alternative solution is to have a single target that dispatches to an MSBuild invoked target with as many Global properties removed as possible. My team have a target in the InitialTargets of a Directory.Build.props Import'ed props file - something like:
Since MSBuild appears to synchronize parallel builds on the {project file, global properties, target}
set, then by removing all of the properties you can synchronize the build and run it once for all projects being built. The downside: you have to maintain the RemoveProperties
attribute - MSBuild doesn't have a way to remove all global properties. If something in the build issues a new MSBuild
task with a custom property specified, then you'll get a second instance of the Target invoked.
And - of course - your build will be synchronized on this target. You could try hooking the target up by setting, say, CompileDependsOn
to depend on the Prebuild
target, to allow independent progress in the build. But to have the target run early and ubiquitously using InitialTargets seems like the better option.