aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/simd
diff options
context:
space:
mode:
authorEthan Morgan <ethan@gweithio.com>2026-02-14 16:44:06 +0000
committerEthan Morgan <ethan@gweithio.com>2026-02-14 16:44:06 +0000
commit54409423f767d8b1cf30cb7d0efca6b4ca138823 (patch)
treed915ac7828703ce4b963efdd9728a1777ba18c1e /vcpkg/ports/simd
move to own git serverHEADmaster
Diffstat (limited to 'vcpkg/ports/simd')
-rw-r--r--vcpkg/ports/simd/SimdConfig.cmake1
-rw-r--r--vcpkg/ports/simd/fix-platform-detection.patch13
-rw-r--r--vcpkg/ports/simd/portfile.cmake86
-rw-r--r--vcpkg/ports/simd/vcpkg.json18
4 files changed, 118 insertions, 0 deletions
diff --git a/vcpkg/ports/simd/SimdConfig.cmake b/vcpkg/ports/simd/SimdConfig.cmake
new file mode 100644
index 0000000..6e74558
--- /dev/null
+++ b/vcpkg/ports/simd/SimdConfig.cmake
@@ -0,0 +1 @@
+include("${CMAKE_CURRENT_LIST_DIR}/simdtargets.cmake")
diff --git a/vcpkg/ports/simd/fix-platform-detection.patch b/vcpkg/ports/simd/fix-platform-detection.patch
new file mode 100644
index 0000000..9dafbf7
--- /dev/null
+++ b/vcpkg/ports/simd/fix-platform-detection.patch
@@ -0,0 +1,13 @@
+diff --git a/prj/cmake/CMakeLists.txt b/prj/cmake/CMakeLists.txt
+index 1aa93f5..41e56fc 100644
+--- a/prj/cmake/CMakeLists.txt
++++ b/prj/cmake/CMakeLists.txt
+@@ -160,7 +160,7 @@ if(CMAKE_GENERATOR MATCHES "Visual Studio")
+ else()
+ if((CMAKE_SYSTEM_PROCESSOR STREQUAL "i686") OR (CMAKE_SYSTEM_PROCESSOR STREQUAL "x86_64") OR (CMAKE_SYSTEM_PROCESSOR STREQUAL "AMD64"))
+ include(x86.cmake)
+- elseif((CMAKE_SYSTEM_PROCESSOR MATCHES "arm") OR (CMAKE_SYSTEM_PROCESSOR STREQUAL "aarch64"))
++ elseif((CMAKE_SYSTEM_PROCESSOR MATCHES "arm") OR (CMAKE_SYSTEM_PROCESSOR MATCHES "ARM") OR (CMAKE_SYSTEM_PROCESSOR STREQUAL "aarch64"))
+ include(arm.cmake)
+ else()
+ message(FATAL_ERROR "Unknown value of CMAKE_SYSTEM_PROCESSOR!")
diff --git a/vcpkg/ports/simd/portfile.cmake b/vcpkg/ports/simd/portfile.cmake
new file mode 100644
index 0000000..36b932a
--- /dev/null
+++ b/vcpkg/ports/simd/portfile.cmake
@@ -0,0 +1,86 @@
+vcpkg_from_github(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO ermig1979/Simd
+ REF "v${VERSION}"
+ SHA512 56fbbadcf95d385e7b0e72d96e0b8e080370c584218fd3175d4b4270bb4a8c0b46ea77f97d0827bf3da2b86ed02e73bef15987bffe0f5f6cf419873674714512
+ HEAD_REF master
+ PATCHES
+ fix-platform-detection.patch
+)
+
+if(VCPKG_TARGET_IS_WINDOWS AND (VCPKG_TARGET_ARCHITECTURE STREQUAL "x86" OR VCPKG_TARGET_ARCHITECTURE STREQUAL "x64"))
+ if(VCPKG_TARGET_ARCHITECTURE STREQUAL "x86")
+ set(SIMD_PLATFORM "Win32")
+ elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "x64")
+ set(SIMD_PLATFORM "x64")
+ endif()
+
+ if(VCPKG_PLATFORM_TOOLSET MATCHES "v140")
+ set(SOLUTION_TYPE vs2015)
+ elseif(VCPKG_PLATFORM_TOOLSET MATCHES "v141")
+ set(SOLUTION_TYPE vs2017)
+ elseif(VCPKG_PLATFORM_TOOLSET MATCHES "v142")
+ set(SOLUTION_TYPE vs2019)
+ else()
+ set(SOLUTION_TYPE vs2022)
+ endif()
+
+ if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
+ vcpkg_replace_string("${SOURCE_PATH}/src/Simd/SimdConfig.h"
+ "//#define SIMD_STATIC"
+ "#define SIMD_STATIC")
+ vcpkg_replace_string("${SOURCE_PATH}/prj/${SOLUTION_TYPE}/Simd.vcxproj"
+ "<ConfigurationType>DynamicLibrary</ConfigurationType>"
+ "<ConfigurationType>StaticLibrary</ConfigurationType>")
+ file(GLOB_RECURSE PROJ_FILES "${SOURCE_PATH}/prj/${SOLUTION_TYPE}/*.vcxproj")
+ foreach(PROJ_FILE ${PROJ_FILES})
+ vcpkg_replace_string(${PROJ_FILE}
+ " </ClCompile>"
+ " <DebugInformationFormat>OldStyle</DebugInformationFormat>\n </ClCompile>")
+ endforeach()
+ endif()
+
+ if(VCPKG_CRT_LINKAGE STREQUAL "dynamic")
+ file(GLOB_RECURSE PROJ_FILES "${SOURCE_PATH}/prj/${SOLUTION_TYPE}/*.vcxproj")
+ foreach(PROJ_FILE ${PROJ_FILES})
+ vcpkg_replace_string(${PROJ_FILE}
+ " </ClCompile>"
+ " <RuntimeLibrary Condition=\"'$(Configuration)'=='Debug'\">MultiThreadedDebugDLL</RuntimeLibrary>\n <RuntimeLibrary Condition=\"'$(Configuration)'=='Release'\">MultiThreadedDLL</RuntimeLibrary>\n </ClCompile>")
+ endforeach()
+ endif()
+
+ vcpkg_install_msbuild(
+ SOURCE_PATH ${SOURCE_PATH}
+ PROJECT_SUBPATH "/prj/${SOLUTION_TYPE}/Simd.sln"
+ PLATFORM ${SIMD_PLATFORM}
+ TARGET "lib\\Simd"
+ RELEASE_CONFIGURATION "Release"
+ DEBUG_CONFIGURATION "Debug"
+ )
+ vcpkg_copy_pdbs()
+ file(GLOB SIMD_HEADERS "${SOURCE_PATH}/src/Simd/*.hpp" "${SOURCE_PATH}/src/Simd/*.h")
+ file(COPY ${SIMD_HEADERS} DESTINATION "${CURRENT_PACKAGES_DIR}/include/Simd")
+elseif((VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64") AND (VCPKG_DETECTED_CMAKE_CXX_COMPILER_ID STREQUAL "MSVC"))
+ message(FATAL_ERROR "Arm64 building with MSVC is currently not supported.")
+else()
+ if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
+ vcpkg_replace_string("${SOURCE_PATH}/src/Simd/SimdConfig.h"
+ "//#define SIMD_STATIC"
+ "#define SIMD_STATIC"
+ )
+ endif()
+ string(COMPARE EQUAL "${VCPKG_LIBRARY_LINKAGE}" "dynamic" SIMD_SHARED)
+ vcpkg_cmake_configure(
+ SOURCE_PATH "${SOURCE_PATH}/prj/cmake"
+ OPTIONS
+ -DSIMD_TEST=OFF
+ -DSIMD_SHARED=${SIMD_SHARED}
+ -DSIMD_PYTHON=OFF
+ )
+ vcpkg_cmake_install()
+ vcpkg_cmake_config_fixup()
+ file(COPY "${CMAKE_CURRENT_LIST_DIR}/SimdConfig.cmake" DESTINATION "${CURRENT_PACKAGES_DIR}/share/simd/")
+ file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include")
+endif()
+
+vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/LICENSE")
diff --git a/vcpkg/ports/simd/vcpkg.json b/vcpkg/ports/simd/vcpkg.json
new file mode 100644
index 0000000..226a9a1
--- /dev/null
+++ b/vcpkg/ports/simd/vcpkg.json
@@ -0,0 +1,18 @@
+{
+ "name": "simd",
+ "version": "6.2.155",
+ "description": "Simd image processing and machine learning library, designed for C and C++ programmers",
+ "homepage": "https://github.com/ermig1979/Simd",
+ "license": "MIT",
+ "supports": "!(uwp | osx | (arm64 & windows))",
+ "dependencies": [
+ {
+ "name": "vcpkg-cmake",
+ "host": true
+ },
+ {
+ "name": "vcpkg-cmake-config",
+ "host": true
+ }
+ ]
+}