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 60 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 11 commits
Commits
Show all changes
60 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
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
1 change: 1 addition & 0 deletions ports/gmp/portfile.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ vcpkg_extract_source_archive(SOURCE_PATH
subdirs.patch
msvc_symbol.patch
arm64-coff.patch
remove_compiler_info.patch
)

vcpkg_list(SET OPTIONS)
Expand Down
15 changes: 15 additions & 0 deletions ports/gmp/remove_compiler_info.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
diff --git a/gmp-h.in b/gmp-h.in
index 648c933582..fa37296fe4 100644
--- a/gmp-h.in
+++ b/gmp-h.in
@@ -2330,10 +2330,6 @@ enum
GMP_ERROR_MPZ_OVERFLOW = 16
};

-/* Define CC and CFLAGS which were used to build this version of GMP */
-#define __GMP_CC "@CC@"
-#define __GMP_CFLAGS "@CFLAGS@"
-
/* Major version number is the value of __GNU_MP__ too, above. */
#define __GNU_MP_VERSION 6
#define __GNU_MP_VERSION_MINOR 3
2 changes: 1 addition & 1 deletion ports/gmp/vcpkg.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "gmp",
"version": "6.3.0",
"port-version": 1,
"port-version": 2,
"description": "The GNU Multiple Precision Arithmetic Library",
"homepage": "https://gmplib.org",
"license": "LGPL-3.0-only OR GPL-2.0-only",
Expand Down
51 changes: 51 additions & 0 deletions ports/intel-hpc/intel-msvc-env.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
include_guard(GLOBAL)

if(NOT DEFINED ENV{INTEL_TOOLCHAIN_ENV_ALREADY_SET})
set(ONEAPIROOT_DIR "${CMAKE_CURRENT_LIST_DIR}/../../intel-compiler/")
file(GLOB CMPLR_ROOT LIST_DIRECTORIES true "${ONEAPIROOT_DIR}/compiler/*")

cmake_path(CONVERT "$ENV{INCLUDE}" TO_CMAKE_PATH_LIST include_env)
list(PREPEND include_env
"${CMPLR_ROOT}/include"
)
cmake_path(CONVERT "${include_env}" TO_NATIVE_PATH_LIST include_env NORMALIZE)
set(ENV{INCLUDE} "${include_env}")

cmake_path(CONVERT "$ENV{LIB}" TO_CMAKE_PATH_LIST lib_env)
list(PREPEND lib_env
"${CMPLR_ROOT}/lib/clang/19/lib/windows"
"${CMPLR_ROOT}/opt/compiler/lib"
"${CMPLR_ROOT}/lib"
)
cmake_path(CONVERT "${lib_env}" TO_NATIVE_PATH_LIST lib_env NORMALIZE)
set(ENV{LIB} "${lib_env}")

cmake_path(CONVERT "$ENV{PATH}" TO_CMAKE_PATH_LIST path)
list(APPEND path
"${CMPLR_ROOT}/bin"
)
cmake_path(CONVERT "${path}" TO_NATIVE_PATH_LIST path NORMALIZE)
set(ENV{PATH} "${path}")

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

# rem OpenCL FPGA runtime
# if exist "%CMPLR_ROOT%\opt\oclfpga\fpgavars.bat" (
# call "%CMPLR_ROOT%\opt\oclfpga\fpgavars.bat"
# )

# set "PATH=%CMPLR_ROOT%\bin;%PATH%"
# set "PATH=%CMPLR_ROOT%\lib\ocloc;%PATH%"
# if /i "%USE_INTEL_LLVM%"=="1" (
# set "PATH=%CMPLR_ROOT%\bin\compiler;%PATH%"
# )

# set "CPATH=%CMPLR_ROOT%\include;%CPATH%"
# set "INCLUDE=%CMPLR_ROOT%\include;%INCLUDE%"
# set "LIB=%CMPLR_ROOT%\lib\clang\19\lib\windows;%CMPLR_ROOT%\opt\compiler\lib;%CMPLR_ROOT%\lib;%LIB%"
# set "PKG_CONFIG_PATH=%CMPLR_ROOT%\lib\pkgconfig;%PKG_CONFIG_PATH%"

# set "OCL_ICD_FILENAMES=%OCL_ICD_FILENAMES%;%CMPLR_ROOT%\bin\intelocl64_emu.dll;%CMPLR_ROOT%\bin\intelocl64.dll"

# set "CMAKE_PREFIX_PATH=%CMPLR_ROOT%;%CMAKE_PREFIX_PATH%"
81 changes: 81 additions & 0 deletions ports/intel-hpc/portfile.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
set(VCPKG_POLICY_EMPTY_PACKAGE enabled)

set(url "https://registrationcenter-download.intel.com/akdlm/IRC_NAS/f07e32fa-b505-4b90-8a79-e328ce9ad9d6/intel-oneapi-hpc-toolkit-2025.0.0.822_offline.exe")

cmake_path(GET url FILENAME filename )
vcpkg_download_distfile(archive_path
URLS "${url}"
FILENAME "${filename}"
SHA512 589b27f7d67487d87a24c25b651ffef79d4cf4e1dd55c128a50b27c63a8fa3f4675fa7412ebad1e7f6832bfd78a14a978d0889c23583f80b813be724ec9492e4
)

vcpkg_find_acquire_program(7Z)

set(out_dir "${CURRENT_BUILDTREES_DIR}/intel/compiler/")
file(MAKE_DIRECTORY "${out_dir}")

message(STATUS "Extracting ${archive_path} ....")
vcpkg_execute_in_download_mode(
COMMAND "${7Z}" x "${archive_path}" "-o${out_dir}" "-y" "-bso0" "-bsp0"
WORKING_DIRECTORY "${out_dir}"
)
message(STATUS "Finished extracting!")

#configure_file("${CURRENT_PACKAGES_DIR}/intel-extract/license.txt" "${CURRENT_PACKAGES_DIR}/share/${PORT}/coypright" COPYONLY)
# vcpkg_execute_in_download_mode(
# COMMAND "${CURRENT_PACKAGES_DIR}/manual-tools/${PORT}/bootstrapper.exe"
# "-s " "--action install"
# "--components=intel.oneapi.win.cpp-compiler:intel.oneapi.win.ifort-compiler"
# "--eula=accept"
# "--install-dir=${CURRENT_PACKAGES_DIR}/manual-tools/intel"
# "--intel-sw-improvement-program-consent=decline"
# "-p=NEED_VS2017_INTEGRATION=0" "-p=NEED_VS2019_INTEGRATION=0" "-p=NEED_VS2022_INTEGRATION=0"
# "--log-dir=${CURRENT_BUILDTREES_DIR}"
# WORKING_DIRECTORY "${CURRENT_PACKAGES_DIR}/manual-tools/${PORT}"
# )

set(packages
"openmp"
"compilers-common-runtime"
"compilers-common"
"ifort-compiler"
"oneapi-common.vars"
# "intel-pti-dev"
# "ipp" # .devel .runtime cp
# "mkl" # .devel .runtime
# "mpi" # .devel .runtime
"ocloc"
# "tbb" # .devel .runtime
)

list(TRANSFORM packages PREPEND "intel.oneapi.win.")

string(REPLACE "." "\\." package_regex "${packages}")
list(JOIN package_regex "|" package_regex)

file(GLOB extracted_folders LIST_DIRECTORIES true "${out_dir}/packages/*")
file(GLOB extracted_files LIST_DIRECTORIES false "${out_dir}/packages/*")
list(REMOVE_ITEM extracted_folders "${extracted_files}")

list(FILTER extracted_folders INCLUDE REGEX "(${package_regex}),")

foreach(package_folder IN LISTS extracted_folders)
cmake_path(GET package_folder STEM LAST_ONLY packstem)
message(STATUS "Extracting ${packstem} ....")
vcpkg_execute_required_process(
COMMAND "${CMAKE_COMMAND}" "-E" "tar" "-xf" "${package_folder}/cupPayload.cup"
WORKING_DIRECTORY "${CURRENT_PACKAGES_DIR}"
LOGNAME "extract-${TARGET_TRIPLET}-${packstem}"
)
message(STATUS "Finsihed extracting ${packstem}!")

endforeach()

file(RENAME "${CURRENT_PACKAGES_DIR}/_installdir" "${CURRENT_PACKAGES_DIR}/intel-compiler")
file(REMOVE
"${CURRENT_PACKAGES_DIR}/filelist.json"
"${CURRENT_PACKAGES_DIR}/filelist.json.sig"
)

configure_file("${CMAKE_CURRENT_LIST_DIR}/intel-msvc-env.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/intel-msvc-env.cmake" @ONLY)

8 changes: 8 additions & 0 deletions ports/intel-hpc/vcpkg.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"name": "intel-hpc",
"version": "2025.0.0",
"license": "MIT",
"dependencies": [
"vcpkg-tool-lessmsi"
]
}
Loading
Loading