diff options
| author | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
|---|---|---|
| committer | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
| commit | 54409423f767d8b1cf30cb7d0efca6b4ca138823 (patch) | |
| tree | d915ac7828703ce4b963efdd9728a1777ba18c1e /vcpkg/ports/openal-soft | |
Diffstat (limited to 'vcpkg/ports/openal-soft')
| -rw-r--r-- | vcpkg/ports/openal-soft/devendor-fmt.diff | 45 | ||||
| -rw-r--r-- | vcpkg/ports/openal-soft/pkgconfig-cxx.diff | 20 | ||||
| -rw-r--r-- | vcpkg/ports/openal-soft/portfile.cmake | 115 | ||||
| -rw-r--r-- | vcpkg/ports/openal-soft/vcpkg.json | 42 |
4 files changed, 222 insertions, 0 deletions
diff --git a/vcpkg/ports/openal-soft/devendor-fmt.diff b/vcpkg/ports/openal-soft/devendor-fmt.diff new file mode 100644 index 0000000..246a833 --- /dev/null +++ b/vcpkg/ports/openal-soft/devendor-fmt.diff @@ -0,0 +1,45 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index d2a69d4..14fc9b8 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -159,7 +159,8 @@ if(MSVC) + endif() + endif() + +-add_subdirectory(fmt-11.1.1 EXCLUDE_FROM_ALL) ++find_package(fmt CONFIG REQUIRED) ++add_library(alsoft::fmt ALIAS fmt::fmt) + + + set(CPP_DEFS ) # C pre-processor, not C++ +@@ -1440,7 +1441,7 @@ if(LIBTYPE STREQUAL "STATIC") + add_library(${IMPL_TARGET} STATIC ${COMMON_OBJS} ${OPENAL_OBJS} ${ALC_OBJS} ${CORE_OBJS}) + target_compile_definitions(${IMPL_TARGET} PUBLIC AL_LIBTYPE_STATIC) + target_link_libraries(${IMPL_TARGET} PRIVATE ${LINKER_FLAGS} ${EXTRA_LIBS} ${MATH_LIB} +- $<BUILD_LOCAL_INTERFACE:alsoft::fmt>) ++ alsoft::fmt) + + if(WIN32) + # This option is for static linking OpenAL Soft into another project +diff --git a/OpenALConfig.cmake.in b/OpenALConfig.cmake.in +index 9704d3c..ddabb81 100644 +--- a/OpenALConfig.cmake.in ++++ b/OpenALConfig.cmake.in +@@ -1,3 +1,5 @@ ++include(CMakeFindDependencyMacro) ++find_dependency(fmt CONFIG) + cmake_minimum_required(VERSION 3.1...3.18) + + include("${CMAKE_CURRENT_LIST_DIR}/OpenALTargets.cmake") +diff --git a/openal.pc.in b/openal.pc.in +index dfa6f57..e04e807 100644 +--- a/openal.pc.in ++++ b/openal.pc.in +@@ -6,6 +6,7 @@ includedir=@includedir@ + Name: OpenAL + Description: OpenAL is a cross-platform 3D audio API + Requires: @PKG_CONFIG_REQUIRES@ ++Requires.private: fmt + Version: @PACKAGE_VERSION@ + Libs: -L${libdir} -l@LIBNAME@ @PKG_CONFIG_LIBS@ + Libs.private:@PKG_CONFIG_PRIVATE_LIBS@ diff --git a/vcpkg/ports/openal-soft/pkgconfig-cxx.diff b/vcpkg/ports/openal-soft/pkgconfig-cxx.diff new file mode 100644 index 0000000..9bc09f8 --- /dev/null +++ b/vcpkg/ports/openal-soft/pkgconfig-cxx.diff @@ -0,0 +1,20 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index 060a740..d2a69d4 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -1379,6 +1379,15 @@ if(LIBTYPE STREQUAL "STATIC") + set(PKG_CONFIG_PRIVATE_LIBS "${PKG_CONFIG_PRIVATE_LIBS} -l${FLAG}") + endif() + endforeach() ++ foreach(lib IN LISTS CMAKE_CXX_IMPLICIT_LINK_LIBRARIES) ++ if(lib IN_LIST CMAKE_C_IMPLICIT_LINK_LIBRARIES) ++ continue() ++ elseif(EXISTS "${lib}") ++ string(APPEND PKG_CONFIG_PRIVATE_LIBS " ${CMAKE_LINK_LIBRARY_FILE_FLAG}${lib}") ++ else() ++ string(APPEND PKG_CONFIG_PRIVATE_LIBS " ${CMAKE_LINK_LIBRARY_FLAG}${lib}") ++ endif() ++ endforeach() + endif() + + # End configuration diff --git a/vcpkg/ports/openal-soft/portfile.cmake b/vcpkg/ports/openal-soft/portfile.cmake new file mode 100644 index 0000000..a39ebae --- /dev/null +++ b/vcpkg/ports/openal-soft/portfile.cmake @@ -0,0 +1,115 @@ +vcpkg_from_github( + OUT_SOURCE_PATH SOURCE_PATH + REPO kcat/openal-soft + REF ${VERSION} + SHA512 3eebd18de4984691136738e8fe5851ac5dbdc8f17916cc9dcc599bd3bafc400c9dad9dc88844a9b77b1e8e372a041af342421bdf23746dffe4760f8385bd1e53 + HEAD_REF master + PATCHES + pkgconfig-cxx.diff + devendor-fmt.diff +) + +vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS + FEATURES + pipewire ALSOFT_BACKEND_PIPEWIRE + pipewire ALSOFT_REQUIRE_PIPEWIRE + pulseaudio ALSOFT_BACKEND_PULSEAUDIO + pulseaudio ALSOFT_REQUIRE_PULSEAUDIO +) + +if(VCPKG_LIBRARY_LINKAGE STREQUAL "dynamic") + set(OPENAL_LIBTYPE "SHARED") +else() + set(OPENAL_LIBTYPE "STATIC") +endif() + +set(ALSOFT_REQUIRE_LINUX OFF) +set(ALSOFT_REQUIRE_WINDOWS OFF) +set(ALSOFT_REQUIRE_WINDOWS_NOT_UWP OFF) +set(ALSOFT_REQUIRE_APPLE OFF) +set(ALSOFT_CPUEXT_NEON OFF) + +if(VCPKG_TARGET_IS_LINUX) + set(ALSOFT_REQUIRE_LINUX ON) +endif() +if(VCPKG_TARGET_IS_WINDOWS) + set(ALSOFT_REQUIRE_WINDOWS ON) + if(NOT VCPKG_TARGET_IS_UWP) + set(ALSOFT_REQUIRE_WINDOWS_NOT_UWP ON) + endif() +endif() +if(VCPKG_TARGET_IS_OSX OR VCPKG_TARGET_IS_IOS) + set(ALSOFT_REQUIRE_APPLE ON) +endif() +if(VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64") + set(ALSOFT_CPUEXT_NEON ON) +endif() + +vcpkg_find_acquire_program(PKGCONFIG) + +vcpkg_cmake_configure( + SOURCE_PATH "${SOURCE_PATH}" + OPTIONS + ${FEATURE_OPTIONS} + -DALSOFT_CPUEXT_NEON=${ALSOFT_CPUEXT_NEON} + -DALSOFT_EXAMPLES=OFF + -DALSOFT_INSTALL_AMBDEC_PRESETS=OFF + -DALSOFT_INSTALL_CONFIG=OFF + -DALSOFT_INSTALL_HRTF_DATA=OFF + -DALSOFT_NO_CONFIG_UTIL=ON + -DALSOFT_UPDATE_BUILD_VERSION=OFF + -DALSOFT_UTILS=OFF + -DLIBTYPE=${OPENAL_LIBTYPE} + "-DPKG_CONFIG_EXECUTABLE=${PKGCONFIG}" + # order by CMakeLists.txt + -DALSOFT_BACKEND_ALSA=${ALSOFT_REQUIRE_LINUX} + -DALSOFT_REQUIRE_ALSA=${ALSOFT_REQUIRE_LINUX} + -DALSOFT_BACKEND_OSS=OFF + -DALSOFT_BACKEND_SOLARIS=OFF + -DALSOFT_BACKEND_SNDIO=OFF + -DALSOFT_BACKEND_WINMM=OFF + -DALSOFT_BACKEND_DSOUND=${ALSOFT_REQUIRE_WINDOWS_NOT_UWP} + -DALSOFT_REQUIRE_DSOUND=${ALSOFT_REQUIRE_WINDOWS_NOT_UWP} + -DALSOFT_BACKEND_WASAPI=${ALSOFT_REQUIRE_WINDOWS} + -DALSOFT_REQUIRE_WASAPI=${ALSOFT_REQUIRE_WINDOWS} + -DALSOFT_BACKEND_JACK=OFF + -DALSOFT_BACKEND_COREAUDIO=${ALSOFT_REQUIRE_APPLE} + -DALSOFT_REQUIRE_COREAUDIO=${ALSOFT_REQUIRE_APPLE} + -DALSOFT_BACKEND_OBOE=OFF + -DALSOFT_BACKEND_OPENSL=${VCPKG_TARGET_IS_ANDROID} + -DALSOFT_REQUIRE_OPENSL=${VCPKG_TARGET_IS_ANDROID} + -DALSOFT_BACKEND_PORTAUDIO=OFF + -DALSOFT_BACKEND_WAVE=ON + MAYBE_UNUSED_VARIABLES + # NOT WIN32 + ALSOFT_BACKEND_ALSA + ALSOFT_REQUIRE_ALSA + ALSOFT_BACKEND_OSS + ALSOFT_BACKEND_SOLARIS + ALSOFT_BACKEND_SNDIO + # WIN32 + ALSOFT_BACKEND_WINMM + ALSOFT_BACKEND_DSOUND + ALSOFT_REQUIRE_DSOUND + ALSOFT_BACKEND_WASAPI + ALSOFT_REQUIRE_WASAPI +) + +vcpkg_cmake_install() +vcpkg_copy_pdbs() +vcpkg_cmake_config_fixup(CONFIG_PATH "lib/cmake/OpenAL") +vcpkg_fixup_pkgconfig() + +if(VCPKG_LIBRARY_LINKAGE STREQUAL "static") + foreach(HEADER IN ITEMS al.h alc.h) + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/AL/${HEADER}" "defined(AL_LIBTYPE_STATIC)" "1") + endforeach() +endif() + +file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include") +file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/share") + +file(READ "${SOURCE_PATH}/common/pffft.cpp" pffft_license) +string(REGEX REPLACE "[*]/.*" "*/\n" pffft_license "${pffft_license}") +file(WRITE "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/pffft Notice" "${pffft_license}") +vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/COPYING" "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/pffft Notice")
\ No newline at end of file diff --git a/vcpkg/ports/openal-soft/vcpkg.json b/vcpkg/ports/openal-soft/vcpkg.json new file mode 100644 index 0000000..3d6d6a9 --- /dev/null +++ b/vcpkg/ports/openal-soft/vcpkg.json @@ -0,0 +1,42 @@ +{ + "name": "openal-soft", + "version": "1.24.3", + "port-version": 1, + "description": "OpenAL Soft is an LGPL-licensed, cross-platform, software implementation of the OpenAL 3D audio API.", + "homepage": "https://github.com/kcat/openal-soft", + "license": "LGPL-2.0-or-later", + "supports": "!xbox", + "dependencies": [ + { + "name": "alsa", + "platform": "linux" + }, + { + "name": "cppwinrt", + "platform": "uwp" + }, + "fmt", + { + "name": "vcpkg-cmake", + "host": true + }, + { + "name": "vcpkg-cmake-config", + "host": true + } + ], + "features": { + "pipewire": { + "description": "Enable PipeWire backend", + "dependencies": [ + "pipewire" + ] + }, + "pulseaudio": { + "description": "Enable PulseAudio backend", + "dependencies": [ + "pulseaudio" + ] + } + } +} |