2018-08-08 19:15:13 +08:00
# vcpkg_install_msbuild
2021-03-11 01:56:07 +08:00
The latest version of this document lives in the [vcpkg repo ](https://github.com/Microsoft/vcpkg/blob/master/docs/maintainers/vcpkg_install_msbuild.md ).
2021-03-01 05:17:19 +08:00
2019-03-11 11:31:02 +08:00
Build and install a msbuild-based project. This replaces `vcpkg_build_msbuild()` .
2018-08-08 19:15:13 +08:00
## Usage
```cmake
vcpkg_install_msbuild(
SOURCE_PATH < ${SOURCE_PATH}>
PROJECT_SUBPATH < port.sln >
[INCLUDES_SUBPATH < include > ]
[LICENSE_SUBPATH < LICENSE > ]
[RELEASE_CONFIGURATION < Release > ]
[DEBUG_CONFIGURATION < Debug > ]
[TARGET < Build > ]
[TARGET_PLATFORM_VERSION < 10.0.15063.0 > ]
[PLATFORM < ${TRIPLET_SYSTEM_ARCH}>]
[PLATFORM_TOOLSET < ${VCPKG_PLATFORM_TOOLSET}>]
[OPTIONS < /p:ZLIB_INCLUDE_PATH=X>...]
[OPTIONS_RELEASE < /p:ZLIB_LIB=X>...]
[OPTIONS_DEBUG < /p:ZLIB_LIB=X>...]
[USE_VCPKG_INTEGRATION]
[ALLOW_ROOT_INCLUDES | REMOVE_ROOT_INCLUDES]
)
```
## Parameters
### SOURCE_PATH
The path to the root of the source tree.
Because MSBuild uses in-source builds, the source tree will be copied into a temporary location for the build. This
parameter is the base for that copy and forms the base for all XYZ_SUBPATH options.
### USE_VCPKG_INTEGRATION
Apply the normal `integrate install` integration for building the project.
By default, projects built with this command will not automatically link libraries or have header paths set.
### PROJECT_SUBPATH
The subpath to the solution (`.sln`) or project (`.vcxproj`) file relative to `SOURCE_PATH` .
### LICENSE_SUBPATH
The subpath to the license file relative to `SOURCE_PATH` .
### INCLUDES_SUBPATH
The subpath to the includes directory relative to `SOURCE_PATH` .
This parameter should be a directory and should not end in a trailing slash.
### ALLOW_ROOT_INCLUDES
Indicates that top-level include files (e.g. `include/zlib.h` ) should be allowed.
### REMOVE_ROOT_INCLUDES
Indicates that top-level include files (e.g. `include/Makefile.am` ) should be removed.
2018-10-26 03:34:45 +08:00
### SKIP_CLEAN
Indicates that the intermediate files should not be removed.
Ports using this option should later call [`vcpkg_clean_msbuild()` ](vcpkg_clean_msbuild.md ) to manually clean up.
2018-08-08 19:15:13 +08:00
### RELEASE_CONFIGURATION
The configuration (``/p:Configuration`` msbuild parameter) used for Release builds.
### DEBUG_CONFIGURATION
2018-10-26 03:34:45 +08:00
The configuration (``/p:Configuration`` msbuild parameter) used for Debug builds.
2018-08-08 19:15:13 +08:00
### TARGET_PLATFORM_VERSION
The WindowsTargetPlatformVersion (``/p:WindowsTargetPlatformVersion`` msbuild parameter)
### TARGET
The MSBuild target to build. (``/t:< TARGET > ``)
### PLATFORM
The platform (``/p:Platform`` msbuild parameter) used for the build.
### PLATFORM_TOOLSET
The platform toolset (``/p:PlatformToolset`` msbuild parameter) used for the build.
### OPTIONS
Additional options passed to msbuild for all builds.
### OPTIONS_RELEASE
Additional options passed to msbuild for Release builds. These are in addition to `OPTIONS` .
### OPTIONS_DEBUG
Additional options passed to msbuild for Debug builds. These are in addition to `OPTIONS` .
## Examples
2018-10-26 03:34:45 +08:00
* [xalan-c ](https://github.com/Microsoft/vcpkg/blob/master/ports/xalan-c/portfile.cmake )
2018-08-08 19:15:13 +08:00
* [libimobiledevice ](https://github.com/Microsoft/vcpkg/blob/master/ports/libimobiledevice/portfile.cmake )
## Source
2021-03-01 05:17:19 +08:00
[scripts/cmake/vcpkg\_install\_msbuild.cmake ](https://github.com/Microsoft/vcpkg/blob/master/scripts/cmake/vcpkg_install_msbuild.cmake )