天天看點

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

      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. 

<ItemDefinitionGroup>
    <CustomBuildStep>
      <Command>makecab.exe $(ProjectDir)main.cpp $(TargetName).cab</Command>
      <Outputs>$(TargetName).cab</Outputs>
      <Inputs>$(TargetFileName)</Inputs>
    </CustomBuildStep>
  </ItemDefinitionGroup>      

To define where in the build the custom build step will execute

      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.

<PropertyGroup>
  <CustomBuildAfterTargets>ClCompile</CustomBuildAfterTargets>
  <CustomBuildBeforeTargets>Link</CustomBuildBeforeTargets>
</PropertyGroup>