Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Targets must be ordered if the input to one target depends on the output of another target. You can use these attributes to specify the order in which targets are run:
- InitialTargets. This- Projectattribute specifies the targets that will run first, even if targets are specified on the command line or in the- DefaultTargetsattribute.
- DefaultTargets. This- Projectattribute specifies which targets are run if a target isn't specified explicitly on the command line.
- DependsOnTargets. This- Targetattribute specifies targets that must run before this target can run.
- BeforeTargetsand- AfterTargets. These- Targetattributes specify that this target should run before or after the specified targets.
In general, you shouldn't depend on the declaration order to specify what tasks run before other tasks.
A target is never run twice during a build, even if a subsequent target in the build depends on it. Once a target has been run, its contribution to the build is complete.
Targets can have a Condition attribute. If the specified condition evaluates to false, the target isn't executed and has no effect on the build. For more information about conditions, see Conditions.
Initial targets
The InitialTargets attribute of the Project element specifies targets that will run first, even if targets are specified on the command line or in the DefaultTargets attribute. Initial targets are typically used for error checking.
The value of the InitialTargets attribute can be a semicolon-delimited, ordered list of targets. The following example specifies that the Warm target runs, and then the Eject target runs.
<Project InitialTargets="Warm;Eject">
Imported projects can have their own InitialTargets attributes. All initial targets are aggregated together and run in order.
For more information, see How to: Specify which target to build first.
Default targets
The DefaultTargets attribute of the Project element specifies which target or targets are built if a target isn't specified explicitly in a command line.
The value of the DefaultTargets attribute can be a semicolon-delimited, ordered list of default targets. The following example specifies that the Clean target runs, and then the Build target runs.
<Project DefaultTargets="Clean;Build">
You can override the default targets by using the -target switch on the command line. The following example specifies that the Build target runs, and then the Report target runs. When you specify targets in this way, any default targets are ignored.
msbuild -target:Build;Report
If both initial targets and default targets are specified, and if no command-line targets are specified, MSBuild runs the initial targets first, and then runs the default targets.
Imported projects can have their own DefaultTargets attributes. The first DefaultTargets attribute encountered determines which default targets will run.
For more information, see How to: Specify which target to build first.
First target
If there are no initial targets, default targets, or command-line targets, then MSBuild runs the first target it encounters in the project file or any imported project files.
Target dependencies
Targets can describe dependency relationships with each other. The DependsOnTargets attribute indicates that a target depends on other targets. For example,
<Target Name="Serve" DependsOnTargets="Chop;Cook" />
tells MSBuild that the Serve target depends on the Chop target and the Cook target. MSBuild runs the Chop target, and then runs the Cook target before it runs the Serve target.
Note
The standard targets in the SDK define a number of DependsOn properties that contain the list of targets that are dependencies for that target (for example, $(BuildDependsOn), $(CleanDependsOn), and so on). For example,
<Target Name="Build" DependsOnTargets="$(BuildDependsOn)">
To customize a project, you can override the DependsOn properties with additional custom targets that extend the build process, as described in Extend the Visual Studio build process.
BeforeTargets and AfterTargets
You can specify target order by using the BeforeTargets and AfterTargets attributes.
Consider the following script.
<Project DefaultTargets="Compile;Link">
    <Target Name="Compile">
        <Message Text="Compiling" />
    </Target>
    <Target Name="Link">
        <Message Text="Linking" />
    </Target>
</Project>
To create an intermediate target Optimize that runs after the Compile target, but before the Link target, add the following target anywhere in the Project element.
<Target Name="Optimize" AfterTargets="Compile">
    <Message Text="Optimizing" />
</Target>
Alternately, specify the order as
<Target Name="Optimize" BeforeTargets="Link">
    <Message Text="Optimizing" />
</Target>
It isn't useful to specify both BeforeTargets and AfterTargets on the same target. As described in the next section, only the first target encountered will cause the new target to run.
Determine the target build order
MSBuild determines the target build order as follows:
- InitialTargetstargets are run.
- Targets specified on the command line by the -target switch are run. If you specify no targets on the command line, then the - DefaultTargetstargets are run. If neither is present, then the first target encountered is run.
- The - Conditionattribute of the target is evaluated. If the- Conditionattribute is present and evaluates to- false, the target isn't executed and has no further effect on the build.- Other targets that list the conditional target in - BeforeTargetsor- AfterTargetsstill execute in the prescribed order, regardless of the result of the condition.
- Before the target is executed or skipped, its - DependsOnTargetstargets are run, unless the- Conditionattribute is applied to the target and evaluates to- false.- Note - A target is considered skipped if it isn't executed because its output items are up-to-date (see incremental build). This check is done just before executing the tasks inside the target, and does not affect the order of execution of targets. 
- Before the target is executed or skipped, any other target that lists the target in a - BeforeTargetsattribute is run.
- Before the target is executed, its - Inputsattribute and- Outputsattribute are compared. If MSBuild determines that any output files are out of date with respect to the corresponding input file or files, then MSBuild executes the target. Otherwise, MSBuild skips the target.
- After the target is executed or skipped, any other target that lists it in an - AfterTargetsattribute is run.