Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[POC|Invalid] Testing vcpkg without installed MSVC #42129

Draft
wants to merge 61 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
61 commits
Select commit Hold shift + click to select a range
4b98150
[Invalid] Testing vcpkg without installed MSVC
Neumann-A Nov 12, 2024
5e74626
use lessmsi
Neumann-A Nov 12, 2024
13f4af9
update to 17.12. calc some versions
Neumann-A Nov 13, 2024
c668ae1
Fix details
Neumann-A Nov 14, 2024
59df484
include net 4.8.x
Neumann-A Nov 14, 2024
1a274d0
commit download generator
Neumann-A Nov 15, 2024
68f934f
Fix MSBuild
Neumann-A Nov 15, 2024
054908a
Fix Fortran stuff
Neumann-A Nov 16, 2024
5df3d96
Fix stuff detecting libm.lib from the intel compiler
Neumann-A Nov 17, 2024
e6e9900
update cmake to 3.31.0
Neumann-A Nov 21, 2024
b4bc90f
adjust cmake generator instance
Neumann-A Nov 21, 2024
0a72041
Only set GENERATOR_INSTANCE if supprted by generator
Neumann-A Nov 22, 2024
c023f86
fix single config build
Neumann-A Nov 23, 2024
24c76d9
fix include order
Neumann-A Nov 23, 2024
74f5fc5
Fix msbuild builds
Neumann-A Nov 27, 2024
c759757
fix easyhook
Neumann-A Nov 29, 2024
6a8088e
fix ffnvcodec
Neumann-A Nov 29, 2024
2ec7776
fix xqilla
Neumann-A Nov 29, 2024
6e78d24
Merge branch 'windows-triplet-without-installed-msvc' of https://gith…
Neumann-A Nov 29, 2024
c3ceef3
fix arpack-ng missing fortran
Neumann-A Nov 29, 2024
ee45443
fix usd
Neumann-A Nov 29, 2024
18e5c19
increase ninja version
Neumann-A Nov 29, 2024
db6afdf
adjust components
Neumann-A Nov 29, 2024
bd42c64
duilib fix single config
Neumann-A Nov 29, 2024
9fac459
fix marble
Neumann-A Nov 29, 2024
b6b62f9
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Nov 30, 2024
574cd1a
fix stuff
Neumann-A Nov 30, 2024
335598e
more fixers
Neumann-A Nov 30, 2024
c47e8d5
fix stuff
Neumann-A Dec 1, 2024
ab745ae
print sdk version
Neumann-A Dec 1, 2024
c5d6b80
fix crashpad
Neumann-A Dec 1, 2024
4ea0520
set policy 0149 to new in toolchain
Neumann-A Dec 1, 2024
a632a24
update to 17.12.3
Neumann-A Dec 4, 2024
b4dd862
install vcvars64.bat
Neumann-A Dec 9, 2024
d813402
Fix vcvars stuff
Neumann-A Dec 9, 2024
572c8d4
fix kf5texteditor
Neumann-A Dec 10, 2024
448a4ad
Try fixing stuff but it probably won't work
Neumann-A Dec 11, 2024
206cb47
Try setting CMAKE_WINDOWS_KITS_10_DIR
Neumann-A Dec 11, 2024
68ce61e
do not build qtwebengine opencv4 llvm
Neumann-A Dec 11, 2024
dbaad07
set policy outside the toolchain
Neumann-A Dec 12, 2024
7627178
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Dec 12, 2024
89c261e
Merge branch 'windows-triplet-without-installed-msvc' of https://gith…
Neumann-A Dec 12, 2024
23b5965
fix abs path
Neumann-A Dec 12, 2024
12bb0dc
fix pdcurses
Neumann-A Dec 12, 2024
ad2ab67
more fixes
Neumann-A Dec 12, 2024
312720c
fix a few failures
Neumann-A Dec 14, 2024
866e7d5
fix g2o
Neumann-A Dec 14, 2024
eeb2cf9
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Dec 14, 2024
4091ec1
fix openmvg
Neumann-A Dec 14, 2024
130bebb
abs path fix
Neumann-A Dec 14, 2024
24952b2
fix patch
Neumann-A Dec 15, 2024
e6db172
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Dec 23, 2024
93ac702
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Jan 4, 2025
8a33676
Adjust to different vs installation approach, add llvm
Neumann-A Jan 4, 2025
8c3343e
Adjust paths and port names
Neumann-A Jan 5, 2025
26f048a
cleanup
Neumann-A Jan 6, 2025
9c8db0b
Fix clang-cl python
Neumann-A Jan 6, 2025
3fd9721
Fix more ports
Neumann-A Jan 8, 2025
f001738
fix a bit
Neumann-A Jan 12, 2025
f93dc7f
update and fix protobuf
Neumann-A Jan 15, 2025
55d1b68
Merge remote-tracking branch 'upstream/master' into windows-triplet-w…
Neumann-A Jan 15, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -290,7 +290,7 @@ __pycache__/
/packages/
/scripts/buildsystems/tmp/
#ignore custom triplets
/triplets/*

#add vcpkg-designed triplets back in
!/triplets/arm-uwp.cmake
!/triplets/arm64-windows.cmake
Expand Down
348 changes: 348 additions & 0 deletions ports/msvc/download_msbuild.cmake

Large diffs are not rendered by default.

1,401 changes: 1,401 additions & 0 deletions ports/msvc/download_sdk.cmake

Large diffs are not rendered by default.

1,182 changes: 1,182 additions & 0 deletions ports/msvc/download_toolkit.cmake

Large diffs are not rendered by default.

19 changes: 19 additions & 0 deletions ports/msvc/extract-vsix.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
param (
[Parameter(Mandatory=$true)]
[string]$VsixFile,
[Parameter(Mandatory=$true)]
[string]$ExtractTo = "install"
)

Add-Type -AssemblyName System.IO.Compression.FileSystem
[System.IO.Compression.ZipFile]::OpenRead(${VsixFile}).Entries |
Where-Object { $_.FullName -like 'Contents/*' } |
ForEach-Object {
$relativePath = $_.FullName.Substring(9) # Remove 'Contents/'
$outputPath = Join-Path -Path ${ExtractTo} -ChildPath $relativePath
$parentPath = [System.IO.Path]::GetDirectoryName($outputPath)
if(-not (Test-Path -Path $parentPath)) {
New-Item -Path $parentPath -ItemType Directory -Force
}
[System.IO.Compression.ZipFileExtensions]::ExtractToFile($_, $outputPath, $true) # Extract entry to the install folder
}
Empty file added ports/msvc/msvc-config.cmake
Empty file.
101 changes: 101 additions & 0 deletions ports/msvc/msvc-env.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
include_guard(GLOBAL)

if(NOT DEFINED ENV{VCPKG_TOOLCHAIN_ENV_ALREADY_SET})
set(MSVC_DIR "${CMAKE_CURRENT_LIST_DIR}/../../")
set(VS_DIR "${CMAKE_CURRENT_LIST_DIR}/../../VS")
set(SDK_DIR "${CMAKE_CURRENT_LIST_DIR}/../../WinSDK")

set(WinSDK_VERSION "@WinSDK_VERSION@")
set(VCToolkit_VERSION "@VCToolkit_VERSION@")
set(VCToolkit_REDIST_VERSION "@VCToolkit_REDIST_VERSION@")

set(systemroot "$ENV{SystemRoot}")
string(REPLACE "\\" "/" systemroot "${systemroot}")

set(LIB
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/ATLMFC/lib/x64"
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/lib/x64"
"${SDK_DIR}/Windows Kits/NETFXSDK/4.8.1/lib/um/x64" #
"${SDK_DIR}/Windows Kits/10/lib/${WinSDK_VERSION}/ucrt/x64"
"${SDK_DIR}/Windows Kits/10/lib/${WinSDK_VERSION}/um/x64"
)
cmake_path(CONVERT "${LIB}" TO_NATIVE_PATH_LIST LIB NORMALIZE)
set(ENV{LIB} "${LIB}")
set(LIBPATH
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/ATLMFC/lib/x64"
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/lib/x64"
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/lib/x86/store/references"
"${SDK_DIR}/Windows Kits/10/UnionMetadata/${WinSDK_VERSION}"
"${SDK_DIR}/Windows Kits/10/References/${WinSDK_VERSION}"
"${systemroot}/Microsoft.NET/Framework64/v4.0.30319"
)
cmake_path(CONVERT "${LIBPATH}" TO_NATIVE_PATH_LIST LIBPATH NORMALIZE)
set(ENV{LIBPATH} "${LIBPATH}")
set(INCLUDE
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/include"
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/ATLMFC/include"
"${VS_DIR}/VC/Auxiliary/VS/include"
"${SDK_DIR}/Windows Kits/10/include/${WinSDK_VERSION}/ucrt"
"${SDK_DIR}/Windows Kits/10/include/${WinSDK_VERSION}/um"
"${SDK_DIR}/Windows Kits/10/include/${WinSDK_VERSION}/shared"
"${SDK_DIR}/Windows Kits/10/include/${WinSDK_VERSION}/winrt"
"${SDK_DIR}/Windows Kits/10/include/${WinSDK_VERSION}/cppwinrt"
"${SDK_DIR}/Windows Kits/NETFXSDK/4.8.1/include/um" #
)
cmake_path(CONVERT "${INCLUDE}" TO_NATIVE_PATH_LIST INCLUDE NORMALIZE)
set(ENV{INCLUDE} "${INCLUDE}")
set(EXTERNAL_INCLUDE ${INCLUDE})
cmake_path(CONVERT "${EXTERNAL_INCLUDE}" TO_NATIVE_PATH_LIST EXTERNAL_INCLUDE NORMALIZE)

set(ENV{EXTERNAL_INCLUDE} "${EXTERNAL_INCLUDE}")
set(ENV{DevEnvDir} "${VS_DIR}/Common7/IDE/")
set(ENV{ExtensionSdkDir} "${SDK_DIR}/Windows Kits/10/ExtensionSDKs")
set(ENV{UniversalCRTSdkDir} "${SDK_DIR}/Windows Kits/10/")
set(ENV{UCRTVersion} "${WinSDK_VERSION}")
set(ENV{VCIDEInstallDir} "${VS_DIR}/Common7/IDE/VC/")
set(ENV{VCINSTALLDIR} "${VS_DIR}/VC/")
set(ENV{VCToolsInstallDir} "${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/")
set(ENV{VCToolsRedistDir} "${VS_DIR}/VC/Redist/MSVC/${VCToolkit_REDIST_VERSION}/")
set(ENV{VCToolsVersion} "${VCToolkit_VERSION}")
set(ENV{VisualStudioVersion} "17.0")
set(ENV{VS170COMNTOOLS} "${VS_DIR}/Common7/Tools/")
set(ENV{VSINSTALLDIR} "${VS_DIR}/")
set(WindowsLibPath
"${SDK_DIR}/Windows Kits/10/UnionMetadata/${WinSDK_VERSION}"
"${SDK_DIR}/Windows Kits/10/References/${WinSDK_VERSION}"
)
cmake_path(CONVERT "${WindowsLibPath}" TO_NATIVE_PATH_LIST WindowsLibPath NORMALIZE)
set(ENV{WindowsLibPath} "${WindowsLibPath}")
set(ENV{WindowsSdkBinPath} "${SDK_DIR}/Windows Kits/10/bin/")
set(ENV{WindowsSdkDir} "${SDK_DIR}/Windows Kits/10/")
set(ENV{WindowsSDKLibVersion} "${WinSDK_VERSION}\\")
set(ENV{WindowsSdkVerBinPath} "${SDK_DIR}/Windows Kits/10/bin/${WinSDK_VERSION}/")
set(ENV{WindowsSDKVersion} "${WinSDK_VERSION}\\")
set(WindowsSDK_ExecutablePath_x64 "${SDK_DIR}/Microsoft SDKs/Windows/v10.0A/bin/NETFX 4.8.1 Tools/x64/") #
set(WindowsSDK_ExecutablePath_x86 "${SDK_DIR}/Microsoft SDKs/Windows/v10.0A/bin/NETFX 4.8.1 Tools/") #
set(ADD_TO_PATH
"${VS_DIR}/VC/Tools/MSVC/${VCToolkit_VERSION}/bin/HostX64/x64"
#${VS_DIR}/Common7/IDE/VC/VCPackages
#${VS_DIR}/Common7/IDE/CommonExtensions/Microsoft/TestWindow
#${VS_DIR}/Common7/IDE/CommonExtensions/Microsoft/TeamFoundation/Team Explorer
"${VS_DIR}/MSBuild/Current/bin/Roslyn"
"${SDK_DIR}/Microsoft SDKs/Windows/v10.0A/bin/NETFX 4.8.1 Tools/x64/" #
#C:/Program Files (x86)/HTML Help Workshop
#${VS_DIR}/Common7/IDE/CommonExtensions/Microsoft/FSharp/Tools
#${VS_DIR}/Team Tools/DiagnosticsHub/Collector
"${SDK_DIR}/Windows Kits/10/bin/${WinSDK_VERSION}/x64"
"${SDK_DIR}/Windows Kits/10/bin/x64"
"${VS_DIR}/MSBuild/Current/Bin/"
#${VS_DIR}/Common7/IDE/
#${VS_DIR}/Common7/Tools/
)
cmake_path(CONVERT "$ENV{PATH}" TO_CMAKE_PATH_LIST path)
list(PREPEND path ${ADD_TO_PATH})

cmake_path(CONVERT "${path}" TO_NATIVE_PATH_LIST path NORMALIZE)
set(ENV{PATH} "${path}")

set(ENV{VCPKG_TOOLCHAIN_ENV_ALREADY_SET} "1")
endif()

set(MSVC_FOUND TRUE)
25 changes: 25 additions & 0 deletions ports/msvc/portfile.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
set(VCPKG_POLICY_DLLS_WITHOUT_LIBS enabled)
set(VCPKG_POLICY_EMPTY_INCLUDE_FOLDER enabled)
set(VCPKG_POLICY_SKIP_COPYRIGHT_CHECK enabled)

find_program(pwsh_exe NAMES pwsh powershell)

include("${CMAKE_CURRENT_LIST_DIR}/portfile_winsdk.cmake")
include("${CMAKE_CURRENT_LIST_DIR}/portfile_toolkit.cmake")
include("${CMAKE_CURRENT_LIST_DIR}/portfile_msbuild.cmake")

if(NOT VCPKG_CRT_LINKAGE STREQUAL "static")
file(COPY "${CURRENT_PACKAGES_DIR}/VS/VC/Redist/MSVC/${VCToolkit_REDIST_VERSION}/x64/Microsoft.VC143.CRT/" DESTINATION "${CURRENT_PACKAGES_DIR}/bin")
file(COPY "${CURRENT_PACKAGES_DIR}/VS/VC/Redist/MSVC/${VCToolkit_REDIST_VERSION}/x64/Microsoft.VC143.MFC/" DESTINATION "${CURRENT_PACKAGES_DIR}/bin")
file(COPY "${CURRENT_PACKAGES_DIR}/WinSDK/Windows Kits/10/Redist/${WinSDK_VERSION}/ucrt/DLLs/x64/" DESTINATION "${CURRENT_PACKAGES_DIR}/bin")

if(NOT VCPKG_BUILD_TYPE)
file(COPY "${CURRENT_PACKAGES_DIR}/VS/VC/Redist/MSVC/${VCToolkit_REDIST_VERSION}/debug_nonredist/x64/Microsoft.VC143.DebugCRT/" DESTINATION "${CURRENT_PACKAGES_DIR}/debug/bin")
file(COPY "${CURRENT_PACKAGES_DIR}/VS/VC/Redist/MSVC/${VCToolkit_REDIST_VERSION}/debug_nonredist/x64/Microsoft.VC143.DebugMFC/" DESTINATION "${CURRENT_PACKAGES_DIR}/debug/bin")
file(COPY "${CURRENT_PACKAGES_DIR}/WinSDK/Windows Kits/10/bin/${WinSDK_VERSION}/x64/ucrt" DESTINATION "${CURRENT_PACKAGES_DIR}/debug/bin")
file(COPY "${CURRENT_PACKAGES_DIR}/WinSDK/Windows Kits/10/Redist/${WinSDK_VERSION}/ucrt/DLLs/x64/" DESTINATION "${CURRENT_PACKAGES_DIR}/debug/bin" PATTERN "ucrtbase.dll" EXCLUDE)
endif()
endif()

configure_file("${CMAKE_CURRENT_LIST_DIR}/msvc-config.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/${PORT}-config.cmake" @ONLY)
configure_file("${CMAKE_CURRENT_LIST_DIR}/msvc-env.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/msvc-env.cmake" @ONLY)
66 changes: 66 additions & 0 deletions ports/msvc/portfile_msbuild.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
block()
set(MSBuild_FILES "")
include("${CMAKE_CURRENT_LIST_DIR}/download_msbuild.cmake")
set(prefix MSBuild)

foreach(item IN LISTS ${prefix}_FILES)
vcpkg_download_distfile(
downloaded_file
URLS "${${prefix}_${item}_URL}"
FILENAME "VS-${VERSION}/MSBuild/${${prefix}_${item}_FILENAME}"
SHA512 "${${prefix}_${item}_SHA512}"
)

list(APPEND vsix_installers "${downloaded_file}")
endforeach()

set(counter 0)
foreach(item IN LISTS vsix_installers)
vcpkg_execute_required_process(
COMMAND "${pwsh_exe}" -ExecutionPolicy Bypass -File "${CMAKE_CURRENT_LIST_DIR}/extract-vsix.ps1" "-VsixFile" "${item}" "-ExtractTo" "${CURRENT_PACKAGES_DIR}/VS"
WORKING_DIRECTORY "${CURRENT_BUILDTREES_DIR}"
LOGNAME "extract_msbuild_${counter}.log"
)
endforeach()

set(msbuild_base "${CURRENT_PACKAGES_DIR}/VS/MSBuild/Microsoft/VC/v170/")
set(winsdk_props "${msbuild_base}/Microsoft.Cpp.WindowsSDK.props")
set(vc_common_props "${msbuild_base}/Microsoft.Cpp.Common.props")
file(READ "${winsdk_props}" winsdk_props_content)
string(REPLACE
[[<_LatestWindowsTargetPlatformVersion>$([Microsoft.Build.Utilities.ToolLocationHelper]::GetLatestSDKTargetPlatformVersion($(SDKIdentifier), $(SDKVersion)))</_LatestWindowsTargetPlatformVersion>]]
"<_LatestWindowsTargetPlatformVersion>${WinSDK_VERSION}</_LatestWindowsTargetPlatformVersion>"
winsdk_props_content
"${winsdk_props_content}"
)
string(REPLACE
[[<WindowsSdkDir_10 Condition=\"'$(WindowsSdkDir_10)' == ''\">$(Registry:HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Microsoft SDKs\\Windows\\v10.0@InstallationFolder)</WindowsSdkDir_10>]]
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
""
winsdk_props_content
"${winsdk_props_content}"
)
string(REPLACE
[[<WindowsSdkDir_10 Condition=\"'$(WindowsSdkDir_10)' == ''\">$(Registry:HKEY_LOCAL_MACHINE\\SOFTWARE\\Wow6432Node\\Microsoft\\Microsoft SDKs\\Windows\\v10.0@InstallationFolder)</WindowsSdkDir_10>]]
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
"<WindowsSdkDir_10 Condition=\"'$(WindowsSdkDir_10)' == ''\">$(MSBuildThisFileDirectory)\\..\\..\\..\\..\\..\\WinSDK\\Windows Kits\\10\\</WindowsSdkDir_10>"
winsdk_props_content
"${winsdk_props_content}"
)
string(REPLACE
[[<UniversalCRTSdkDir_10 Condition=\"'$(UniversalCRTSdkDir_10)' == ''\">$(Registry:HKEY_LOCAL_MACHINE\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows Kits\\Installed Roots@KitsRoot10)</UniversalCRTSdkDir_10>]]
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
""
winsdk_props_content
"${winsdk_props_content}"
)
string(REPLACE
[[<UniversalCRTSdkDir_10 Condition=\"'$(UniversalCRTSdkDir_10)' == ''\">$(Registry:HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows Kits\\Installed Roots@KitsRoot10)</UniversalCRTSdkDir_10>]]
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
"<UniversalCRTSdkDir_10 Condition=\"'$(UniversalCRTSdkDir_10)' == ''\">$(MSBuildThisFileDirectory)\\..\\..\\..\\..\\..\\WinSDK\\Windows Kits\\10\\</UniversalCRTSdkDir_10>"
winsdk_props_content
"${winsdk_props_content}"
)
file(WRITE "${winsdk_props}" "${winsdk_props_content}")

vcpkg_replace_string("${vc_common_props}"
[[<VSInstallDir>$(VsInstallRoot)\</VSInstallDir>]]
"<VSInstallDir>$(MSBuildThisFileDirectory)\\..\\..\\..\\..\\</VSInstallDir>"
)
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
endblock()
56 changes: 56 additions & 0 deletions ports/msvc/portfile_toolkit.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
block(PROPAGATE VCToolkit_VERSION VCToolkit_REDIST_VERSION)
set(VCToolkit_FILES "")
include("${CMAKE_CURRENT_LIST_DIR}/download_toolkit.cmake")
set(prefix VCToolkit)

set(vsix_installers "")
set(msi_installers "")
foreach(item IN LISTS VCToolkit_FILES)
vcpkg_download_distfile(
downloaded_file
URLS "${${prefix}_${item}_URL}"
FILENAME "VS-${VERSION}/VS/${${prefix}_${item}_FILENAME}"
SHA512 "${${prefix}_${item}_SHA512}"
)

if(${prefix}_${item}_FILENAME MATCHES ".vsix$")
list(APPEND vsix_installers "${downloaded_file}")
endif()
if(${prefix}_${item}_FILENAME MATCHES ".msi$")
list(APPEND msi_installers "${downloaded_file}")
endif()
endforeach()

set(counter 0)
foreach(item IN LISTS vsix_installers)
math(EXPR counter "${counter} + 1")
message(STATUS "Extracting '${item}'")
vcpkg_execute_required_process(
COMMAND "${pwsh_exe}" -ExecutionPolicy Bypass -File "${CMAKE_CURRENT_LIST_DIR}/extract-vsix.ps1" "-VsixFile" "${item}" "-ExtractTo" "${CURRENT_PACKAGES_DIR}/VS"
WORKING_DIRECTORY "${CURRENT_BUILDTREES_DIR}"
LOGNAME "extract_toolkit_${counter}.log"
)
endforeach()

set(installFolderSdk "${CURRENT_PACKAGES_DIR}/WinSDK")

foreach(msi IN LISTS msi_installers)
vcpkg_extract_with_lessmsi(
MSI "${msi}"
DESTINATION "${installFolderSdk}"
)
endforeach()

file(COPY "${installFolderSdk}/Program Files/Windows Kits/" DESTINATION "${installFolderSdk}/Windows Kits/")
file(COPY "${installFolderSdk}/Program Files/Microsoft SDKs/" DESTINATION "${installFolderSdk}")
file(COPY "${installFolderSdk}/Program Files/Reference Assemblies/" DESTINATION "${installFolderSdk}")

file(REMOVE_RECURSE "${installFolderSdk}/Program Files")

file(GLOB vc_redist_version_folder LIST_DIRECTORIES true "${CURRENT_PACKAGES_DIR}/VS/VC/Redist/MSVC/*")
cmake_path(GET vc_redist_version_folder FILENAME VCToolkit_REDIST_VERSION)
file(GLOB vc_toolkit_version_folder LIST_DIRECTORIES true "${CURRENT_PACKAGES_DIR}/VS/VC/Tools/MSVC/*")
cmake_path(GET vc_toolkit_version_folder FILENAME VCToolkit_VERSION)
endblock()

#D:\vcpkg_folders\no_msvc\packages\msvc_x64-windows-release\VS\VC\Tools\MSVC\14.41.34120
97 changes: 97 additions & 0 deletions ports/msvc/portfile_winsdk.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
block(PROPAGATE WinSDK_VERSION)
set(WinSDK_FILES "")
include("${CMAKE_CURRENT_LIST_DIR}/download_sdk.cmake")

set(to_skip
"MsiVal2-x86_en-us"
"Orca-x86_en-us"
"Windows App Certification Kit x86-x86_en-us"
"Windows App Certification Kit x86 \\(OnecoreUAP\\)-x86_en-us"
"Windows SDK for Windows Store Apps Legacy Tools-x86_en-us"
"Windows SDK-x86_en-us"
)

set(match_skip
"DirectX"
"Certification Kit Native Components"
"Windows App Certification Kit Native Components"
"Universal CRT Tools"
"Application Verifier"
)

list(APPEND to_skip ${match_skip})

list(JOIN to_skip "|" to_skip_regex)
set(to_skip_regex "(${to_skip_regex})")

set(exclude_from_skip
"Application Verifier x64 ExternalPackage (DesktopEditions)-x64_en-us"
"Application Verifier x64 ExternalPackage (OnecoreUAP)-x64_en-us"
)
list(JOIN exclude_from_skip "|" exclude_regex)
set(exclude_regex "(${exclude_regex})")

set(prefix WinSDK)

foreach(sdkitem IN LISTS WinSDK_FILES)
set(skip FALSE)
string(TOLOWER "${${prefix}_${sdkitem}_FILENAME}" filename_lower)

if( "${${prefix}_${sdkitem}_FILENAME}" MATCHES "${to_skip_regex}" AND
NOT "${${prefix}_${sdkitem}_FILENAME}" MATCHES "${exclude_regex}")
message(STATUS "Skipping '${${prefix}_${sdkitem}_FILENAME}'")
continue()
endif()

set(filename "${${prefix}_${sdkitem}_FILENAME}")
if(NOT "${filename_lower}" MATCHES "winsdk(installer|setup)")
string(PREPEND filename "Installers/")
endif()

vcpkg_download_distfile(
downloaded_file
URLS "${${prefix}_${sdkitem}_URL}"
FILENAME "VS-${VERSION}/WinSDK/${filename}"
SHA512 "${${prefix}_${sdkitem}_SHA512}"
)

if(downloaded_file MATCHES ".msi$")
list(APPEND msi_installers "${downloaded_file}")
endif()
endforeach()

set(installFolderSdk "${CURRENT_PACKAGES_DIR}/WinSDK")

set(counter 0)
foreach(msi IN LISTS msi_installers)
math(EXPR counter "${counter} + 1")

vcpkg_extract_with_lessmsi(
MSI "${msi}"
DESTINATION "${installFolderSdk}"
)

# Handle extra categories
foreach(pattern IN LISTS exclude_from_skip)
if(skip AND componentName MATCHES "${pattern}")
file(GLOB_RECURSE catFiles "${installLocation}/*.cat")
set(catalogsPath "${installFolderSdk}/Program Files/Windows Kits/10/Catalogs")
file(MAKE_DIRECTORY "${catalogsPath}")
foreach(catFile IN LISTS catFiles)
file(COPY "${catFile}" DESTINATION "${catalogsPath}")
endforeach()
endif()
endforeach()

# Handle specific component
if(componentName MATCHES "WindowsAppCertificationKitNativeComponents-x64_en-us")
set(kitsPath "${installFolderSdk}/Windows Kits")
file(MAKE_DIRECTORY "${kitsPath}")
file(COPY "${installLocation}/Windows Kits" DESTINATION "${kitsPath}")
endif()
endforeach()

# Remove unknown stuff
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/WinSDK/Windows App Certification Kit/")
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/WinSDK/Microsoft/")
Neumann-A marked this conversation as resolved.
Show resolved Hide resolved
endblock()
8 changes: 8 additions & 0 deletions ports/msvc/vcpkg.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"name": "msvc",
"version": "17.12.0",
"license": "MIT",
"dependencies": [
"vcpkg-tool-lessmsi"
]
}
5 changes: 4 additions & 1 deletion ports/vcpkg-cmake/vcpkg.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,8 @@
"name": "vcpkg-cmake",
"version-date": "2024-04-23",
"documentation": "https://learn.microsoft.com/vcpkg/maintainers/functions/vcpkg_cmake_configure",
"license": "MIT"
"license": "MIT",
"dependencies" : [
"msvc"
]
}
Loading
Loading