---
description: "Learn more about: How to: Add a Custom Build Step to MSBuild Projects"
title: "How to: Add a Custom Build Step to MSBuild Projects"
ms.date: "10/16/2019"
helpviewer_keywords: ["msbuild (c++), howto: add a custom build step"]
ms.assetid: a20a0c47-4df4-4754-a1f0-a94a99958916
---
# How to: Add a Custom Build Step to MSBuild Projects
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 `CustomBuildAfterTargets` and `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.
Specify the `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 `CustomBuildBeforeTargets` and `CustomBuildAfterTargets` XML elements. Therefore, specify those targets just one time in your project file.
### To define what is executed by the custom build step
1. 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 C++ Project](walkthrough-using-msbuild-to-create-a-visual-cpp-project.md).
```
makecab.exe $(ProjectDir)main.cpp $(TargetName).cab
$(TargetName).cab
$(ProjectDir)main.cpp
```
### To define where in the build the custom build step will execute
1. 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.
```
ClCompile
Link
```
## See also
[Walkthrough: Using MSBuild to Create a C++ Project](walkthrough-using-msbuild-to-create-a-visual-cpp-project.md)
[How to: Use Build Events in MSBuild Projects](how-to-use-build-events-in-msbuild-projects.md)
[How to: Add Custom Build Tools to MSBuild Projects](how-to-add-custom-build-tools-to-msbuild-projects.md)