#[===[.md: # vcpkg_install_msbuild Build and install a msbuild-based project. This replaces `vcpkg_build_msbuild()`. ## Usage ```cmake vcpkg_install_msbuild( SOURCE_PATH <${SOURCE_PATH}> PROJECT_SUBPATH [INCLUDES_SUBPATH ] [LICENSE_SUBPATH ] [RELEASE_CONFIGURATION ] [DEBUG_CONFIGURATION ] [TARGET ] [TARGET_PLATFORM_VERSION <10.0.15063.0>] [PLATFORM <${TRIPLET_SYSTEM_ARCH}>] [PLATFORM_TOOLSET <${VCPKG_PLATFORM_TOOLSET}>] [OPTIONS ...] [OPTIONS_RELEASE ...] [OPTIONS_DEBUG ...] [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. ### 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. ### RELEASE_CONFIGURATION The configuration (``/p:Configuration`` msbuild parameter) used for Release builds. ### DEBUG_CONFIGURATION The configuration (``/p:Configuration`` msbuild parameter) used for Debug builds. ### TARGET_PLATFORM_VERSION The WindowsTargetPlatformVersion (``/p:WindowsTargetPlatformVersion`` msbuild parameter) ### TARGET The MSBuild target to build. (``/t:``) ### 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 * [xalan-c](https://github.com/Microsoft/vcpkg/blob/master/ports/xalan-c/portfile.cmake) * [libimobiledevice](https://github.com/Microsoft/vcpkg/blob/master/ports/libimobiledevice/portfile.cmake) #]===] include(vcpkg_clean_msbuild) function(vcpkg_install_msbuild) # parse parameters such that semicolons in options arguments to COMMAND don't get erased cmake_parse_arguments( PARSE_ARGV 0 _csc "USE_VCPKG_INTEGRATION;ALLOW_ROOT_INCLUDES;REMOVE_ROOT_INCLUDES;SKIP_CLEAN" "SOURCE_PATH;PROJECT_SUBPATH;INCLUDES_SUBPATH;LICENSE_SUBPATH;RELEASE_CONFIGURATION;DEBUG_CONFIGURATION;PLATFORM;PLATFORM_TOOLSET;TARGET_PLATFORM_VERSION;TARGET" "OPTIONS;OPTIONS_RELEASE;OPTIONS_DEBUG" ) if(NOT DEFINED _csc_RELEASE_CONFIGURATION) set(_csc_RELEASE_CONFIGURATION Release) endif() if(NOT DEFINED _csc_DEBUG_CONFIGURATION) set(_csc_DEBUG_CONFIGURATION Debug) endif() if(NOT DEFINED _csc_PLATFORM) if(VCPKG_TARGET_ARCHITECTURE STREQUAL x64) set(_csc_PLATFORM x64) elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL x86) set(_csc_PLATFORM Win32) elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL ARM) set(_csc_PLATFORM ARM) elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL arm64) set(_csc_PLATFORM arm64) else() message(FATAL_ERROR "Unsupported target architecture") endif() endif() if(NOT DEFINED _csc_PLATFORM_TOOLSET) set(_csc_PLATFORM_TOOLSET ${VCPKG_PLATFORM_TOOLSET}) endif() if(NOT DEFINED _csc_TARGET_PLATFORM_VERSION) vcpkg_get_windows_sdk(_csc_TARGET_PLATFORM_VERSION) endif() if(NOT DEFINED _csc_TARGET) set(_csc_TARGET Rebuild) endif() list(APPEND _csc_OPTIONS /t:${_csc_TARGET} /p:Platform=${_csc_PLATFORM} /p:PlatformToolset=${_csc_PLATFORM_TOOLSET} /p:VCPkgLocalAppDataDisabled=true /p:UseIntelMKL=No /p:WindowsTargetPlatformVersion=${_csc_TARGET_PLATFORM_VERSION} /p:VcpkgTriplet=${TARGET_TRIPLET} "/p:VcpkgCurrentInstalledDir=${CURRENT_INSTALLED_DIR}" /p:VcpkgManifestInstall=false /m ) if(VCPKG_LIBRARY_LINKAGE STREQUAL "static") # Disable LTCG for static libraries because this setting introduces ABI incompatibility between minor compiler versions # TODO: Add a way for the user to override this if they want to opt-in to incompatibility list(APPEND _csc_OPTIONS /p:WholeProgramOptimization=false) endif() if(_csc_USE_VCPKG_INTEGRATION) list(APPEND _csc_OPTIONS /p:ForceImportBeforeCppTargets=${SCRIPTS}/buildsystems/msbuild/vcpkg.targets /p:VcpkgApplocalDeps=false) endif() get_filename_component(SOURCE_PATH_SUFFIX "${_csc_SOURCE_PATH}" NAME) if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release") message(STATUS "Building ${_csc_PROJECT_SUBPATH} for Release") file(REMOVE_RECURSE ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel) file(MAKE_DIRECTORY ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel) file(COPY ${_csc_SOURCE_PATH} DESTINATION ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel) set(SOURCE_COPY_PATH ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/${SOURCE_PATH_SUFFIX}) vcpkg_execute_required_process( COMMAND msbuild ${SOURCE_COPY_PATH}/${_csc_PROJECT_SUBPATH} /p:Configuration=${_csc_RELEASE_CONFIGURATION} ${_csc_OPTIONS} ${_csc_OPTIONS_RELEASE} WORKING_DIRECTORY ${SOURCE_COPY_PATH} LOGNAME build-${TARGET_TRIPLET}-rel ) file(GLOB_RECURSE LIBS ${SOURCE_COPY_PATH}/*.lib) file(GLOB_RECURSE DLLS ${SOURCE_COPY_PATH}/*.dll) file(GLOB_RECURSE EXES ${SOURCE_COPY_PATH}/*.exe) if(LIBS) file(COPY ${LIBS} DESTINATION ${CURRENT_PACKAGES_DIR}/lib) endif() if(DLLS) file(COPY ${DLLS} DESTINATION ${CURRENT_PACKAGES_DIR}/bin) endif() if(EXES) file(COPY ${EXES} DESTINATION ${CURRENT_PACKAGES_DIR}/tools/${PORT}) vcpkg_copy_tool_dependencies(${CURRENT_PACKAGES_DIR}/tools/${PORT}) endif() endif() if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug") message(STATUS "Building ${_csc_PROJECT_SUBPATH} for Debug") file(REMOVE_RECURSE ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg) file(MAKE_DIRECTORY ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg) file(COPY ${_csc_SOURCE_PATH} DESTINATION ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg) set(SOURCE_COPY_PATH ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg/${SOURCE_PATH_SUFFIX}) vcpkg_execute_required_process( COMMAND msbuild ${SOURCE_COPY_PATH}/${_csc_PROJECT_SUBPATH} /p:Configuration=${_csc_DEBUG_CONFIGURATION} ${_csc_OPTIONS} ${_csc_OPTIONS_DEBUG} WORKING_DIRECTORY ${SOURCE_COPY_PATH} LOGNAME build-${TARGET_TRIPLET}-dbg ) file(GLOB_RECURSE LIBS ${SOURCE_COPY_PATH}/*.lib) file(GLOB_RECURSE DLLS ${SOURCE_COPY_PATH}/*.dll) if(LIBS) file(COPY ${LIBS} DESTINATION ${CURRENT_PACKAGES_DIR}/debug/lib) endif() if(DLLS) file(COPY ${DLLS} DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin) endif() endif() vcpkg_copy_pdbs() if(NOT _csc_SKIP_CLEAN) vcpkg_clean_msbuild() endif() if(DEFINED _csc_INCLUDES_SUBPATH) file(COPY ${_csc_SOURCE_PATH}/${_csc_INCLUDES_SUBPATH}/ DESTINATION ${CURRENT_PACKAGES_DIR}/include/) file(GLOB ROOT_INCLUDES LIST_DIRECTORIES false ${CURRENT_PACKAGES_DIR}/include/*) if(ROOT_INCLUDES) if(_csc_REMOVE_ROOT_INCLUDES) file(REMOVE ${ROOT_INCLUDES}) elseif(_csc_ALLOW_ROOT_INCLUDES) else() message(FATAL_ERROR "Top-level files were found in ${CURRENT_PACKAGES_DIR}/include; this may indicate a problem with the call to `vcpkg_install_msbuild()`.\nTo avoid conflicts with other libraries, it is recommended to not put includes into the root `include/` directory.\nPass either ALLOW_ROOT_INCLUDES or REMOVE_ROOT_INCLUDES to handle these files.\n") endif() endif() endif() if(DEFINED _csc_LICENSE_SUBPATH) file(INSTALL ${_csc_SOURCE_PATH}/${_csc_LICENSE_SUBPATH} DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright) endif() endfunction()