How to: Add a Custom Build Step to MSBuild Projects
For the latest documentation on Visual Studio 2017 RC, see Visual Studio 2017 RC Documentation.
A custom build step is a user-defined step in a build. A custom build step behaves like any other command tool step, such as the standard compile or link tool step.
Specify a custom build step in the project file (.vcxproj). The step can specify a command line to execute, any additional input or output files, and a message to display. If MSBuild determines that your output files are out-of-date with regard to your input files, it displays the message and executes the command.
To specify the location of the custom build step in the sequence of build targets, use one or both of the
CustomBuildBeforeTargets XML elements in the project file. For example, you could specify that the custom build step runs after the link tool target and before the manifest tool target. The actual set of available targets depends on your particular build.
CustomBuildBeforeTargets element to execute the custom build step before a particular target runs, the
CustomBuildAfterTargets element to execute the step after a particular target runs, or both elements to execute the step between two adjacent targets. If neither element is specified, your custom build tool executes at its default location, which is after the Link target.
Custom build steps and custom build tools share the information specified in the
CustomBuildAfterTargets XML elements. Therefore, specify those targets just one time in your project file.
Add a property group to the project file. In this property group, specify the command, its inputs and outputs, and a message, as shown in the following example. This example creates a .cab file from the main.cpp file you created in Walkthrough: Using MSBuild to Create a Visual C++ Project.
<ItemDefinitionGroup> <CustomBuildStep> <Command>makecab.exe $(ProjectDir)main.cpp $(TargetName).cab</Command> <Outputs>$(TargetName).cab</Outputs> <Inputs>$(TargetFileName)</Inputs> </CustomBuildStep> </ItemDefinitionGroup>
Add the following property group to the project file. You can specify both targets, or you can omit one if you just want the custom step to execute before or after a particular target. This example tells MSBuild to perform the custom step after the compile step but before the link step.
<PropertyGroup> <CustomBuildAfterTargets>ClCompile</CustomBuildAfterTargets> <CustomBuildBeforeTargets>Link</CustomBuildBeforeTargets> </PropertyGroup>