From 1d6e1be7ac3b4535f178d24d53e6eeee6ba674e1 Mon Sep 17 00:00:00 2001 From: "Matthias C. M. Troffaes" Date: Wed, 9 Jun 2021 23:25:20 +0100 Subject: [PATCH] [ffmpeg] use pkgconfig to get system dependencies for cmake (#17985) * [ffmpeg] use ffbuild/config.mak to get dependencies * [ffmpeg] bump port version * [ffmpeg] x-add-version * [ffmpeg] fix dependency issue on x64-linux * [ffmpeg] x-add-version * [ffmpeg] link order fix on linux * [ffmpeg] x-add-version * [ffmpeg] bump port version * [ffmpeg] x-add-version * [ffmpeg] exclude -lgcc and -lgcc_s (causes issues on azure for unknown reasons) * [ffmpeg] x-add-version * [ffmpeg] handle -lgcc and -lgcc_s appropriately * [ffmpeg] x-add-version * [ffmpeg] use x_vcpkg_pkgconfig_get_modules to get info, added some more fixes to generated for pkgconfig files * [ffmpeg] report dependencies (for now, helps debugging) * [vcpkg-pkgconfig-get-modules] bump port version * [ffmpeg] [vcpkg-pkgconfig-get-modules] x-add-version * [ffmpeg] fix variant issue * [ffmpeg] x-add-version * [ffmpeg] reformat manifest * [ffmpeg] x-add-version * [ffmpeg] remove duplicate avfilter library from dependencies * [ffmpeg] fix -pthread / -pthreads on linux * [ffmpeg] x-add-version * [ffmpeg] fix dynamic builds when no libraries need to be linked * [ffmpeg] x-add-version * [ffmpeg] disable openh264 on uwp when building all * [ffmpeg] x-add-version * [avcpp] fix uwp build failure due to deprecations treated as errors * [avcpp] bump port version * [avcpp] x-add-version * [avcpp] smaller patch * [avcpp] x-add-version * [ffmpeg] x-add-version --- .../0002-av_init_packet_deprecation.patch | 16 + ports/avcpp/portfile.cmake | 1 + ports/avcpp/vcpkg.json | 1 + ports/ffmpeg/FindFFMPEG.cmake.in | 353 ++---------------- ports/ffmpeg/portfile.cmake | 190 +++++----- ports/ffmpeg/vcpkg.json | 16 +- ports/vcpkg-pkgconfig-get-modules/vcpkg.json | 3 +- .../x_vcpkg_pkgconfig_get_modules.cmake | 4 +- versions/a-/avcpp.json | 5 + versions/baseline.json | 6 +- versions/f-/ffmpeg.json | 5 + versions/v-/vcpkg-pkgconfig-get-modules.json | 5 + 12 files changed, 178 insertions(+), 427 deletions(-) create mode 100644 ports/avcpp/0002-av_init_packet_deprecation.patch diff --git a/ports/avcpp/0002-av_init_packet_deprecation.patch b/ports/avcpp/0002-av_init_packet_deprecation.patch new file mode 100644 index 00000000000000..a243b0dfef1183 --- /dev/null +++ b/ports/avcpp/0002-av_init_packet_deprecation.patch @@ -0,0 +1,16 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index a5fed05..7875b91 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -24,6 +24,11 @@ set (AVCPP_WARNING_OPTIONS + $<$: + /W4>) + ++# fixes vcpkg uwp failures due to /sdl ++if(MSVC) ++ add_compile_options(/wd4996) ++endif() ++ + # -pthread sets also some useful compile-time flags + set(THREADS_PREFER_PTHREAD_FLAG ON) + find_package(Threads) diff --git a/ports/avcpp/portfile.cmake b/ports/avcpp/portfile.cmake index d6412fce8b13d1..c472590ee1e34b 100644 --- a/ports/avcpp/portfile.cmake +++ b/ports/avcpp/portfile.cmake @@ -9,6 +9,7 @@ vcpkg_from_github( HEAD_REF master PATCHES 0001-remove-problematic-compound-literal.patch + 0002-av_init_packet_deprecation.patch ) string(COMPARE EQUAL "${VCPKG_LIBRARY_LINKAGE}" "static" AVCPP_ENABLE_STATIC) diff --git a/ports/avcpp/vcpkg.json b/ports/avcpp/vcpkg.json index afb9a18a44a490..8a2495d98e80c5 100644 --- a/ports/avcpp/vcpkg.json +++ b/ports/avcpp/vcpkg.json @@ -1,6 +1,7 @@ { "name": "avcpp", "version-date": "2021-05-06", + "port-version": 1, "description": "Wrapper for the FFmpeg that simplify usage it from C++ projects.", "homepage": "https://github.com/h4tr3d/avcpp", "dependencies": [ diff --git a/ports/ffmpeg/FindFFMPEG.cmake.in b/ports/ffmpeg/FindFFMPEG.cmake.in index 9991a3488186e8..0c98b655884f97 100644 --- a/ports/ffmpeg/FindFFMPEG.cmake.in +++ b/ports/ffmpeg/FindFFMPEG.cmake.in @@ -39,310 +39,39 @@ if(SEARCH_PATH STREQUAL "/") set(SEARCH_PATH "") endif() -function(select_library_configurations_from_names) - cmake_parse_arguments(_slc "" "BASENAME" "NAMES;NAMES_RELEASE;NAMES_DEBUG" ${ARGN}) - list(APPEND _slc_NAMES_RELEASE ${_slc_NAMES}) - list(APPEND _slc_NAMES_DEBUG ${_slc_NAMES}) - find_library(${_slc_BASENAME}_LIBRARY_RELEASE NAMES ${_slc_NAMES_RELEASE} PATHS ${SEARCH_PATH}/lib/ NO_DEFAULT_PATH) - find_library(${_slc_BASENAME}_LIBRARY_DEBUG NAMES ${_slc_NAMES_DEBUG} PATHS ${SEARCH_PATH}/debug/lib/ NO_DEFAULT_PATH) - select_library_configurations(${_slc_BASENAME}) - set(${_slc_BASENAME}_LIBRARIES ${${_slc_BASENAME}_LIBRARIES} PARENT_SCOPE) -endfunction() +set(FFMPEG_VERSION "@FFMPEG_VERSION@") -function(select_library_configurations_from_targets) - cmake_parse_arguments(_slc "" "BASENAME" "TARGETS" ${ARGN}) - foreach(_target ${_slc_TARGETS}) - get_target_property(_rel ${_target} IMPORTED_LOCATION_RELEASE) - get_target_property(_dbg ${_target} IMPORTED_LOCATION_DEBUG) - get_target_property(_deps ${_target} INTERFACE_LINK_LIBRARIES) - list(APPEND ${_slc_BASENAME}_LIBRARY_RELEASE ${_rel}) - list(APPEND ${_slc_BASENAME}_LIBRARY_DEBUG ${_dbg}) - foreach(_dep ${_deps}) - if(TARGET ${_dep}) - get_target_property(_dep_rel ${_dep} IMPORTED_LOCATION_RELEASE) - get_target_property(_dep_dbg ${_dep} IMPORTED_LOCATION_DEBUG) - if(_dep_rel MATCHES _dep_rel-NOTFOUND) - set(_dep_rel ${_dep_dbg}) - elseif(_dep_dbg MATCHES _dep_dbg-NOTFOUND) - set(_dep_dbg ${_dep_rel}) - endif() - list(APPEND ${_slc_BASENAME}_LIBRARY_RELEASE ${_dep_rel}) - list(APPEND ${_slc_BASENAME}_LIBRARY_DEBUG ${_dep_dbg}) - elseif(NOT ${_dep} MATCHES _deps-NOTFOUND) - if(${_dep} MATCHES ::) - #TODO Handle targets contained in cmake generator expressions - message(STATUS Unhandled dependency ${_slc_BASENAME}: ${_dep}) +function(append_dependencies out) + cmake_parse_arguments(PARSE_ARGV 1 "arg" "DEBUG" "NAMES" "") + if(${arg_DEBUG}) + set(config DEBUG) + set(path "${CURRENT_INSTALLED_DIR}/debug/lib/") + else() + set(config RELEASE) + set(path "${CURRENT_INSTALLED_DIR}/lib/") + endif() + foreach(lib_name ${arg_NAMES}) + if("${lib_name}" STREQUAL "-pthread") + list(APPEND ${out} "-pthread") + elseif("${lib_name}" STREQUAL "-pthreads") + list(APPEND ${out} "-pthreads") + elseif("${lib_name}" STREQUAL "gcc") + list(APPEND ${out} "-lgcc") + elseif("${lib_name}" STREQUAL "gcc_s") + list(APPEND ${out} "-lgcc_s") + elseif("${lib_name}" STREQUAL "stdc++") + list(APPEND ${out} "-lstdc++") else() - list(APPEND ${_slc_BASENAME}_DEP_LIBRARIES ${_dep}) + # first look in ${path} specifically to ensure we find the right release/debug variant + find_library(FFMPEG_DEPENDENCY_${lib_name}_${config} NAMES "${lib_name}" PATHS "${path}" NO_DEFAULT_PATH) + # if not found there, must be a system dependency, so look elsewhere + find_library(FFMPEG_DEPENDENCY_${lib_name}_${config} NAMES "${lib_name}" REQUIRED) + list(APPEND ${out} "${FFMPEG_DEPENDENCY_${lib_name}_${config}}") endif() - endif() endforeach() - endforeach() - select_library_configurations(${_slc_BASENAME}) - list(APPEND ${_slc_BASENAME}_LIBRARIES ${${_slc_BASENAME}_DEP_LIBRARIES}) - set(${_slc_BASENAME}_LIBRARIES ${${_slc_BASENAME}_LIBRARIES} PARENT_SCOPE) + set("${out}" "${${out}}" PARENT_SCOPE) endfunction() -# for finding system libraries (e.g. Apple framework libraries) -function(find_platform_dependent_libraries) - cmake_parse_arguments(_fpd "" "" "NAMES" ${ARGN}) - foreach(_name ${_fpd_NAMES}) - find_library(${_name}_LIBRARY ${_name} REQUIRED) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${${_name}_LIBRARY}) - endforeach() - set(FFMPEG_PLATFORM_DEPENDENT_LIBS ${FFMPEG_PLATFORM_DEPENDENT_LIBS} PARENT_SCOPE) -endfunction() - -# for finding system libraries that may not always be available -function(find_platform_dependent_optional_libraries) - cmake_parse_arguments(_fpdo "" "" "NAMES" ${ARGN}) - foreach(_name ${_fpdo_NAMES}) - find_library(${_name}_LIBRARY ${_name}) - if(NOT ${_name}_LIBRARY MATCHES ${_name}_LIBRARY-NOTFOUND) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${${_name}_LIBRARY}) - endif() - endforeach() - set(FFMPEG_PLATFORM_DEPENDENT_LIBS ${FFMPEG_PLATFORM_DEPENDENT_LIBS} PARENT_SCOPE) -endfunction() - -set(FFMPEG_VERSION "@FFMPEG_VERSION@") - -find_dependency(Threads) -if(UNIX) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS -pthread) -endif() - -if(@ENABLE_ASS@) - select_library_configurations_from_names(BASENAME ASS NAMES ass libass) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${ASS_LIBRARIES}) - if(NOT @ENABLE_FREETYPE@) - find_dependency(Freetype) - select_library_configurations_from_targets(BASENAME freetype TARGETS Freetype::Freetype) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${freetype_LIBRARIES}) - endif() - if(NOT @ENABLE_FRIBIDI@) - select_library_configurations_from_names(BASENAME FRIBIDI NAMES fribidi libfribidi) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${FRIBIDI_LIBRARIES}) - endif() - select_library_configurations_from_names(BASENAME HARFBUZZ NAMES harfbuzz libharfbuzz) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${HARFBUZZ_LIBRARIES}) -endif() - -if(@ENABLE_BZIP2@) - find_dependency(BZip2) - select_library_configurations_from_targets(BASENAME BZip2 TARGETS BZip2::BZip2) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${BZip2_LIBRARIES}) -endif() - -if(@ENABLE_DAV1D@) - select_library_configurations_from_names(BASENAME DAV1D NAMES dav1d libdav1d) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${DAV1D_LIBRARIES}) - if(UNIX) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS dl) - endif() -endif() - -if(@ENABLE_ICONV@) - find_dependency(Iconv) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${Iconv_LIBRARIES}) -endif() - -if(@ENABLE_ILBC@) - select_library_configurations_from_names(BASENAME ILBC NAMES ilbc libilbc) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${ILBC_LIBRARIES}) -endif() - -if(@ENABLE_FDKAAC@) - select_library_configurations_from_names(BASENAME FDK NAMES fdk-aac libfdk-aac) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${FDK_LIBRARIES}) -endif() - -if(@ENABLE_FONTCONFIG@) - find_dependency(Fontconfig) - select_library_configurations_from_targets(BASENAME fontconfig TARGETS Fontconfig::Fontconfig) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${fontconfig_LIBRARIES}) -endif() - -if(@ENABLE_FREETYPE@) - find_dependency(Freetype) - select_library_configurations_from_targets(BASENAME freetype TARGETS Freetype::Freetype) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${freetype_LIBRARIES}) -endif() - -if(@ENABLE_FRIBIDI@) - select_library_configurations_from_names(BASENAME FRIBIDI NAMES fribidi libfribidi) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${FRIBIDI_LIBRARIES}) -endif() - -if(@ENABLE_LZMA@) - find_dependency(LibLZMA) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${LibLZMA_LIBRARIES}) -endif() - -if(@ENABLE_LAME@) - find_dependency(mp3lame) - select_library_configurations_from_targets(BASENAME mp3lame TARGETS mp3lame::mp3lame) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${mp3lame_LIBRARIES}) -endif() - -if(@ENABLE_MODPLUG@) - select_library_configurations_from_names(BASENAME MODPLUG NAMES modplug libmodplug) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${MODPLUG_LIBRARIES}) -endif() - -if(@ENABLE_NVCODEC@) - if(UNIX) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS dl) - endif() -endif() - -if(@ENABLE_OPENCL@) - find_dependency(OpenCL) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${OpenCL_LIBRARIES}) -endif() - -if(@ENABLE_OPENGL@) - if(POLICY CMP0072) - cmake_policy (SET CMP0072 OLD) - endif(POLICY CMP0072) - find_dependency(OpenGL) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${OPENGL_LIBRARIES}) -endif() - -if(@ENABLE_OPENH264@) - select_library_configurations_from_names(BASENAME openh264 NAMES openh264) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${openh264_LIBRARIES}) -endif() - -if(@ENABLE_OPENJPEG@) - find_dependency(OpenJPEG) - select_library_configurations_from_targets(BASENAME openjpeg TARGETS openjp2) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${openjpeg_LIBRARIES}) -endif() - -if(@ENABLE_OPENSSL@) - find_dependency(OpenSSL) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${OPENSSL_LIBRARIES}) -endif() - -if(@ENABLE_OPUS@) - find_dependency(Opus) - select_library_configurations_from_targets(BASENAME Opus TARGETS Opus::opus) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${Opus_LIBRARIES}) -endif() - -if(@ENABLE_SDL2@) - find_dependency(SDL2) - if(TARGET SDL2::SDL2-static) - select_library_configurations_from_targets(BASENAME SDL2 TARGETS SDL2::SDL2-static) - else() - select_library_configurations_from_targets(BASENAME SDL2 TARGETS SDL2::SDL2) - endif() - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${SDL2_LIBRARIES}) -endif() - -if(@ENABLE_SNAPPY@) - find_dependency(Snappy) - select_library_configurations_from_targets(BASENAME Snappy TARGETS Snappy::snappy) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${Snappy_LIBRARIES}) -endif() - -if(@ENABLE_SOXR@) - select_library_configurations_from_names(BASENAME SOXR NAMES soxr) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${SOXR_LIBRARIES}) -endif() - -if(@ENABLE_SPEEX@) - if(WIN32) - select_library_configurations_from_names(BASENAME SPEEX NAMES_RELEASE libspeex NAMES_DEBUG libspeexd) - else() - select_library_configurations_from_names(BASENAME SPEEX NAMES speex libspeex) - endif() - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${SPEEX_LIBRARIES}) -endif() - -if(@ENABLE_SSH@) - find_dependency(libssh) - select_library_configurations_from_targets(BASENAME libssh TARGETS ssh) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${libssh_LIBRARIES}) -endif() - -if(@ENABLE_THEORA@) - find_dependency(Ogg) # ensure Ogg::ogg is defined as a target - find_dependency(unofficial-theora) - select_library_configurations_from_targets(BASENAME THEORA TARGETS unofficial::theora::theoraenc) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${THEORA_LIBRARIES}) -endif() - -if(@ENABLE_TESSERACT@) - find_dependency(Tesseract) - select_library_configurations_from_targets(BASENAME tesseract TARGETS libtesseract) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${tesseract_LIBRARIES}) -endif() - -if(@ENABLE_VORBIS@) - find_dependency(Vorbis) - select_library_configurations_from_targets(BASENAME vorbis TARGETS Vorbis::vorbis Vorbis::vorbisenc) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${vorbis_LIBRARIES}) -endif() - -if(@ENABLE_VPX@) - find_dependency(unofficial-libvpx) - select_library_configurations_from_targets(BASENAME libvpx TARGETS unofficial::libvpx::libvpx) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${libvpx_LIBRARIES}) -endif() - -if(@ENABLE_WEBP@) - find_dependency(WebP) - select_library_configurations_from_targets(BASENAME webp TARGETS WebP::webp WebP::webpdemux WebP::libwebpmux WebP::webpdecoder) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${webp_LIBRARIES}) -endif() - -if(@ENABLE_X264@) - select_library_configurations_from_names(BASENAME X264 NAMES x264 libx264) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${X264_LIBRARIES}) - if(UNIX) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS dl) - endif() -endif() - -if(@ENABLE_X265@) - select_library_configurations_from_names(BASENAME X265 NAMES x265 x265-static) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${X265_LIBRARIES}) - if(UNIX) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS dl) - find_platform_dependent_optional_libraries(NAMES numa) - endif() -endif() - -if(@ENABLE_XML2@) - find_dependency(LibXml2) - select_library_configurations_from_targets(BASENAME libxml2 TARGETS LibXml2::LibXml2) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${libxml2_LIBRARIES}) -endif() - -if(@ENABLE_ZLIB@) - find_dependency(ZLIB) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS ${ZLIB_LIBRARIES}) -endif() - -# Platform dependent libraries required by FFMPEG -if(UNIX AND NOT APPLE) - find_platform_dependent_optional_libraries(NAMES Xv X11 Xext) - find_platform_dependent_optional_libraries(NAMES va-drm va vdpau) - if(@ENABLE_AVDEVICE@) - find_platform_dependent_optional_libraries(NAMES xcb xcb-shm xcb-shape xcb-xfixes) - endif() -endif() - -if(WIN32) - if(NOT CYGWIN) - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS wsock32 ws2_32 secur32 bcrypt strmiids Vfw32 Shlwapi mfplat mfuuid) - endif() -else() - list(APPEND FFMPEG_PLATFORM_DEPENDENT_LIBS m) -endif() - macro(FFMPEG_FIND varname shortname headername) if(NOT FFMPEG_${varname}_INCLUDE_DIRS) find_path(FFMPEG_${varname}_INCLUDE_DIRS NAMES lib${shortname}/${headername} ${headername} PATHS ${SEARCH_PATH}/include NO_DEFAULT_PATH) @@ -363,25 +92,6 @@ macro(FFMPEG_FIND varname shortname headername) endif() endmacro(FFMPEG_FIND) -if(APPLE) - find_platform_dependent_libraries(NAMES VideoToolbox CoreServices CoreMedia CoreVideo) - if(@ENABLE_OPENCL@) - find_platform_dependent_libraries(NAMES OpenCL) - endif() - if(@ENABLE_AVDEVICE@) - find_platform_dependent_libraries(NAMES AVFoundation CoreAudio CoreFoundation CoreGraphics Foundation) - endif() - if(@ENABLE_AVFILTER@) - find_platform_dependent_libraries(NAMES OpenGL AppKit CoreImage) - endif() - if(@ENABLE_AVFORMAT@) - find_platform_dependent_libraries(NAMES Security) - endif() - if(@ENABLE_AVCODEC@) - find_platform_dependent_libraries(NAMES AudioToolbox) - endif() -endif() - if(@ENABLE_AVDEVICE@) FFMPEG_FIND(libavdevice avdevice avdevice.h) endif() @@ -435,9 +145,12 @@ if (FFMPEG_libavutil_FOUND) set(FFMPEG_libswscale_VERSION "@LIBSWSCALE_VERSION@" CACHE STRING "") endif() - list(APPEND FFMPEG_LIBRARIES - ${FFMPEG_PLATFORM_DEPENDENT_LIBS} - ) + append_dependencies(FFMPEG_DEPS_LIBRARY_RELEASE NAMES "@FFMPEG_DEPENDENCIES_RELEASE@") + append_dependencies(FFMPEG_DEPS_LIBRARY_DEBUG NAMES "@FFMPEG_DEPENDENCIES_DEBUG@" DEBUG) + if(FFMPEG_DEPS_LIBRARY_RELEASE OR FFMPEG_DEPS_LIBRARY_DEBUG) + select_library_configurations(FFMPEG_DEPS) + list(APPEND FFMPEG_LIBRARIES ${FFMPEG_DEPS_LIBRARY}) + endif() set(FFMPEG_LIBRARY ${FFMPEG_LIBRARIES}) diff --git a/ports/ffmpeg/portfile.cmake b/ports/ffmpeg/portfile.cmake index 56447a98f67e87..d9cc4aadbec4ea 100644 --- a/ports/ffmpeg/portfile.cmake +++ b/ports/ffmpeg/portfile.cmake @@ -103,6 +103,8 @@ set(_csc_PROJECT_PATH ffmpeg) file(REMOVE_RECURSE ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel) +set(FFMPEG_PKGCONFIG_MODULES libavutil) + if("nonfree" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-nonfree") endif() @@ -136,6 +138,7 @@ endif() if("avcodec" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-avcodec") set(ENABLE_AVCODEC ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libavcodec) else() set(OPTIONS "${OPTIONS} --disable-avcodec") set(ENABLE_AVCODEC OFF) @@ -144,6 +147,7 @@ endif() if("avdevice" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-avdevice") set(ENABLE_AVDEVICE ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libavdevice) else() set(OPTIONS "${OPTIONS} --disable-avdevice") set(ENABLE_AVDEVICE OFF) @@ -152,6 +156,7 @@ endif() if("avformat" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-avformat") set(ENABLE_AVFORMAT ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libavformat) else() set(OPTIONS "${OPTIONS} --disable-avformat") set(ENABLE_AVFORMAT OFF) @@ -160,6 +165,7 @@ endif() if("avfilter" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-avfilter") set(ENABLE_AVFILTER ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libavfilter) else() set(OPTIONS "${OPTIONS} --disable-avfilter") set(ENABLE_AVFILTER OFF) @@ -168,6 +174,7 @@ endif() if("postproc" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-postproc") set(ENABLE_POSTPROC ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libpostproc) else() set(OPTIONS "${OPTIONS} --disable-postproc") set(ENABLE_POSTPROC OFF) @@ -176,6 +183,7 @@ endif() if("swresample" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-swresample") set(ENABLE_SWRESAMPLE ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libswresample) else() set(OPTIONS "${OPTIONS} --disable-swresample") set(ENABLE_SWRESAMPLE OFF) @@ -184,6 +192,7 @@ endif() if("swscale" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-swscale") set(ENABLE_SWSCALE ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libswscale) else() set(OPTIONS "${OPTIONS} --disable-swscale") set(ENABLE_SWSCALE OFF) @@ -193,6 +202,7 @@ set(ENABLE_AVRESAMPLE OFF) if("avresample" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-avresample") set(ENABLE_AVRESAMPLE ON) + list(APPEND FFMPEG_PKGCONFIG_MODULES libavresample) endif() set(STATIC_LINKAGE OFF) @@ -200,10 +210,8 @@ if(VCPKG_LIBRARY_LINKAGE STREQUAL "static") set(STATIC_LINKAGE ON) endif() -set(ENABLE_ASS OFF) if("ass" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libass") - set(ENABLE_ASS ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libass") endif() @@ -214,267 +222,201 @@ else() set(OPTIONS "${OPTIONS} --disable-avisynth") endif() -set(ENABLE_BZIP2 OFF) if("bzip2" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-bzlib") - set(ENABLE_BZIP2 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-bzlib") endif() -set(ENABLE_DAV1D OFF) if("dav1d" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libdav1d") - set(ENABLE_DAV1D ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libdav1d") endif() -set(ENABLE_ICONV OFF) if("iconv" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-iconv") - set(ENABLE_ICONV ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-iconv") endif() -set(ENABLE_ILBC OFF) if("ilbc" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libilbc") - set(ENABLE_ILBC ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libilbc") endif() -set(ENABLE_FDKAAC OFF) if("fdk-aac" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libfdk-aac") - set(ENABLE_FDKAAC ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libfdk-aac") endif() -set(ENABLE_FONTCONFIG OFF) if("fontconfig" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libfontconfig") - set(ENABLE_FONTCONFIG ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libfontconfig") endif() -set(ENABLE_FREETYPE OFF) if("freetype" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libfreetype") - set(ENABLE_FREETYPE ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libfreetype") endif() -set(ENABLE_FRIBIDI OFF) if("fribidi" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libfribidi") - set(ENABLE_FRIBIDI ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libfribidi") endif() -set(ENABLE_LZMA OFF) if("lzma" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-lzma") - set(ENABLE_LZMA ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-lzma") endif() -set(ENABLE_LAME OFF) if("mp3lame" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libmp3lame") - set(ENABLE_LAME ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libmp3lame") endif() -set(ENABLE_MODPLUG OFF) if("modplug" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libmodplug") - set(ENABLE_MODPLUG ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libmodplug") endif() -set(ENABLE_NVCODEC OFF) if("nvcodec" IN_LIST FEATURES) #Note: the --enable-cuda option does not actually require the cuda sdk or toolset port dependency as ffmpeg uses runtime detection and dynamic loading - set(ENABLE_NVCODEC ON) set(OPTIONS "${OPTIONS} --enable-cuda --enable-nvenc --enable-nvdec --enable-cuvid --enable-ffnvcodec") else() set(OPTIONS "${OPTIONS} --disable-cuda --disable-nvenc --disable-nvdec --disable-cuvid --disable-ffnvcodec") endif() -set(ENABLE_OPENCL OFF) if("opencl" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-opencl") - set(ENABLE_OPENCL ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-opencl") endif() -set(ENABLE_OPENGL OFF) if("opengl" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-opengl") - set(ENABLE_OPENGL ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-opengl") endif() -set(ENABLE_OPENH264 OFF) if("openh264" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libopenh264") - set(ENABLE_OPENH264 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libopenh264") endif() -set(ENABLE_OPENJPEG OFF) if("openjpeg" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libopenjpeg") - set(ENABLE_OPENJPEG ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libopenjpeg") endif() -set(ENABLE_OPENSSL OFF) if("openssl" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-openssl") - set(ENABLE_OPENSSL ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-openssl") endif() -set(ENABLE_OPUS OFF) if("opus" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libopus") - set(ENABLE_OPUS ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libopus") endif() -set(ENABLE_SDL2 OFF) if("sdl2" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-sdl2") - set(ENABLE_SDL2 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-sdl2") endif() -set(ENABLE_SNAPPY OFF) if("snappy" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libsnappy") - set(ENABLE_SNAPPY ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libsnappy") endif() -set(ENABLE_SOXR OFF) if("soxr" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libsoxr") - set(ENABLE_SOXR ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libsoxr") endif() -set(ENABLE_SPEEX OFF) if("speex" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libspeex") - set(ENABLE_SPEEX ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libspeex") endif() -set(ENABLE_SSH OFF) if("ssh" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libssh") - set(ENABLE_SSH ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libssh") endif() -set(ENABLE_TENSORFLOW OFF) if("tensorflow" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libtensorflow") - set(ENABLE_TENSORFLOW ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libtensorflow") endif() -set(ENABLE_TESSERACT OFF) if("tesseract" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libtesseract") - set(ENABLE_TESSERACT ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libtesseract") endif() -set(ENABLE_THEORA OFF) if("theora" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libtheora") - set(ENABLE_THEORA ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libtheora") endif() -set(ENABLE_VORBIS OFF) if("vorbis" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libvorbis") - set(ENABLE_VORBIS ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libvorbis") endif() -set(ENABLE_VPX OFF) if("vpx" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libvpx") - set(ENABLE_VPX ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libvpx") endif() -set(ENABLE_WEBP OFF) if("webp" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libwebp") - set(ENABLE_WEBP ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libwebp") endif() -set(ENABLE_X264 OFF) if("x264" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libx264") - set(ENABLE_X264 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libx264") endif() -set(ENABLE_X265 OFF) if("x265" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libx265") - set(ENABLE_X265 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libx265") endif() -set(ENABLE_XML2 OFF) if("xml2" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-libxml2") - set(ENABLE_XML2 ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-libxml2") endif() -set(ENABLE_ZLIB OFF) if("zlib" IN_LIST FEATURES) set(OPTIONS "${OPTIONS} --enable-zlib") - set(ENABLE_ZLIB ${STATIC_LINKAGE}) else() set(OPTIONS "${OPTIONS} --disable-zlib") endif() @@ -649,47 +591,97 @@ endif() vcpkg_copy_pdbs() if (VCPKG_TARGET_IS_WINDOWS) - # Translate cygpath to local path - set(CYGPATH_CMD "${MSYS_ROOT}/usr/bin/cygpath.exe" -w) - - foreach(PKGCONFIG_PATH "${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig" "${CURRENT_PACKAGES_DIR}/lib/pkgconfig") - file(GLOB PKGCONFIG_FILES "${PKGCONFIG_PATH}/*.pc") - foreach(PKGCONFIG_FILE IN LISTS PKGCONFIG_FILES) + foreach(_debug "" "/debug") + foreach(PKGCONFIG_MODULE IN LISTS FFMPEG_PKGCONFIG_MODULES) + set(PKGCONFIG_FILE "${CURRENT_PACKAGES_DIR}${_debug}/lib/pkgconfig/${PKGCONFIG_MODULE}.pc") + # remove redundant cygwin style -libpath entries + execute_process( + COMMAND "${MSYS_ROOT}/usr/bin/cygpath.exe" -u "${CURRENT_INSTALLED_DIR}" + OUTPUT_VARIABLE CYG_INSTALLED_DIR + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + vcpkg_replace_string("${PKGCONFIG_FILE}" "-libpath:${CYG_INSTALLED_DIR}${_debug}/lib/pkgconfig/../../lib " "") + # transform libdir, includedir, and prefix paths from cygwin style to windows style file(READ "${PKGCONFIG_FILE}" PKGCONFIG_CONTENT) foreach(PATH_NAME prefix libdir includedir) - string(REGEX MATCH "${PATH_NAME}=[^\n]*\n" PATH_VALUE "${PKGCONFIG_CONTENT}") + string(REGEX MATCH "${PATH_NAME}=[^\n]*" PATH_VALUE "${PKGCONFIG_CONTENT}") string(REPLACE "${PATH_NAME}=" "" PATH_VALUE "${PATH_VALUE}") - string(REPLACE "\n" "" PATH_VALUE "${PATH_VALUE}") - set("${PATH_NAME}_cygpath" "${PATH_VALUE}") + if(NOT PATH_VALUE) + message(FATAL_ERROR "failed to find pkgconfig variable ${PATH_NAME}") + endif() + execute_process( + COMMAND "${MSYS_ROOT}/usr/bin/cygpath.exe" -w "${PATH_VALUE}" + OUTPUT_VARIABLE FIXED_PATH + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + file(TO_CMAKE_PATH "${FIXED_PATH}" FIXED_PATH) + vcpkg_replace_string("${PKGCONFIG_FILE}" "${PATH_NAME}=${PATH_VALUE}" "${PATH_NAME}=${FIXED_PATH}") + endforeach() + # list libraries with -l flag (so pkgconf knows they are libraries and not just linker flags) + foreach(LIBS_ENTRY Libs Libs.private) + string(REGEX MATCH "${LIBS_ENTRY}: [^\n]*" LIBS_VALUE "${PKGCONFIG_CONTENT}") + if(NOT LIBS_VALUE) + message(FATAL_ERROR "failed to find pkgconfig entry ${LIBS_ENTRY}") + endif() + string(REPLACE "${LIBS_ENTRY}: " "" LIBS_VALUE "${LIBS_VALUE}") + if(LIBS_VALUE) + set(LIBS_VALUE_OLD "${LIBS_VALUE}") + string(REGEX REPLACE "([^ ]+)[.]lib" "-l\\1" LIBS_VALUE "${LIBS_VALUE}") + set(LIBS_VALUE_NEW "${LIBS_VALUE}") + vcpkg_replace_string("${PKGCONFIG_FILE}" "${LIBS_ENTRY}: ${LIBS_VALUE_OLD}" "${LIBS_ENTRY}: ${LIBS_VALUE_NEW}") + endif() endforeach() - execute_process( - COMMAND ${CYGPATH_CMD} "${prefix_cygpath}" - OUTPUT_VARIABLE FIXED_PREFIX_PATH - ) - string(REPLACE "\n" "" FIXED_PREFIX_PATH "${FIXED_PREFIX_PATH}") - file(TO_CMAKE_PATH "${FIXED_PREFIX_PATH}" FIXED_PREFIX_PATH) - execute_process( - COMMAND ${CYGPATH_CMD} "${libdir_cygpath}" - OUTPUT_VARIABLE FIXED_LIBDIR_PATH - ) - string(REPLACE "\n" "" FIXED_LIBDIR_PATH ${FIXED_LIBDIR_PATH}) - file(TO_CMAKE_PATH ${FIXED_LIBDIR_PATH} FIXED_LIBDIR_PATH) - execute_process( - COMMAND ${CYGPATH_CMD} "${includedir_cygpath}" - OUTPUT_VARIABLE FIXED_INCLUDE_PATH - ) - string(REPLACE "\n" "" FIXED_INCLUDE_PATH "${FIXED_INCLUDE_PATH}") - file(TO_CMAKE_PATH ${FIXED_INCLUDE_PATH} FIXED_INCLUDE_PATH) - - vcpkg_replace_string("${PKGCONFIG_FILE}" "${prefix_cygpath}" "${FIXED_PREFIX_PATH}") - vcpkg_replace_string("${PKGCONFIG_FILE}" "${libdir_cygpath}" "${FIXED_LIBDIR_PATH}") - vcpkg_replace_string("${PKGCONFIG_FILE}" "${includedir_cygpath}" "${FIXED_INCLUDE_PATH}") endforeach() endforeach() endif() vcpkg_fixup_pkgconfig() +# Handle dependencies + +x_vcpkg_pkgconfig_get_modules(PREFIX FFMPEG_PKGCONFIG MODULES ${FFMPEG_PKGCONFIG_MODULES} LIBS) + +function(append_dependencies_from_libs out) + cmake_parse_arguments(PARSE_ARGV 1 "arg" "" "LIBS" "") + string(REGEX REPLACE "[ ]+" ";" contents "${arg_LIBS}") + list(FILTER contents EXCLUDE REGEX "^-framework$") + list(FILTER contents EXCLUDE REGEX "^-L.+") + list(FILTER contents EXCLUDE REGEX "^-libpath:.+") + list(TRANSFORM contents REPLACE "^-Wl,-framework," "-l") + list(FILTER contents EXCLUDE REGEX "^-Wl,.+") + list(TRANSFORM contents REPLACE "^-l" "") + list(FILTER contents EXCLUDE REGEX "^avresample$") + list(FILTER contents EXCLUDE REGEX "^avutil$") + list(FILTER contents EXCLUDE REGEX "^avcodec$") + list(FILTER contents EXCLUDE REGEX "^avdevice$") + list(FILTER contents EXCLUDE REGEX "^avfilter$") + list(FILTER contents EXCLUDE REGEX "^avformat$") + list(FILTER contents EXCLUDE REGEX "^postproc$") + list(FILTER contents EXCLUDE REGEX "^swresample$") + list(FILTER contents EXCLUDE REGEX "^swscale$") + if(VCPKG_TARGET_IS_WINDOWS) + list(TRANSFORM contents TOLOWER) + endif() + if(contents) + list(APPEND "${out}" "${contents}") + set("${out}" "${${out}}" PARENT_SCOPE) + endif() +endfunction() + +append_dependencies_from_libs(FFMPEG_DEPENDENCIES_RELEASE LIBS "${FFMPEG_PKGCONFIG_LIBS_RELEASE}") +append_dependencies_from_libs(FFMPEG_DEPENDENCIES_DEBUG LIBS "${FFMPEG_PKGCONFIG_LIBS_DEBUG}") + +# must remove duplicates from the front to respect link order so reverse first +list(REVERSE FFMPEG_DEPENDENCIES_RELEASE) +list(REVERSE FFMPEG_DEPENDENCIES_DEBUG) +list(REMOVE_DUPLICATES FFMPEG_DEPENDENCIES_RELEASE) +list(REMOVE_DUPLICATES FFMPEG_DEPENDENCIES_DEBUG) +list(REVERSE FFMPEG_DEPENDENCIES_RELEASE) +list(REVERSE FFMPEG_DEPENDENCIES_DEBUG) + +message("Dependencies (release): ${FFMPEG_DEPENDENCIES_RELEASE}") +message("Dependencies (debug): ${FFMPEG_DEPENDENCIES_DEBUG}") + # Handle version strings function(extract_regex_from_file out) diff --git a/ports/ffmpeg/vcpkg.json b/ports/ffmpeg/vcpkg.json index 09bb81a89bdfcd..ae1d7cbdce436c 100644 --- a/ports/ffmpeg/vcpkg.json +++ b/ports/ffmpeg/vcpkg.json @@ -1,12 +1,18 @@ { "name": "ffmpeg", "version": "4.4", - "port-version": 2, + "port-version": 3, "description": [ "a library to decode, encode, transcode, mux, demux, stream, filter and play pretty much anything that humans and machines have created.", "FFmpeg is the leading multimedia framework, able to decode, encode, transcode, mux, demux, stream, filter and play pretty much anything that humans and machines have created. It supports the most obscure ancient formats up to the cutting edge. No matter if they were designed by some standards committee, the community or a corporation. It is also highly portable: FFmpeg compiles, runs, and passes our testing infrastructure FATE across Linux, Mac OS X, Microsoft Windows, the BSDs, Solaris, etc. under a wide variety of build environments, machine architectures, and configurations." ], "homepage": "https://ffmpeg.org", + "dependencies": [ + { + "name": "vcpkg-pkgconfig-get-modules", + "host": true + } + ], "default-features": [ "avcodec", "avdevice", @@ -29,7 +35,6 @@ "iconv", "lzma", "mp3lame", - "openh264", "openjpeg", "opus", "snappy", @@ -56,6 +61,13 @@ ], "platform": "!uwp" }, + { + "name": "ffmpeg", + "features": [ + "openh264" + ], + "platform": "!uwp" + }, { "name": "ffmpeg", "features": [ diff --git a/ports/vcpkg-pkgconfig-get-modules/vcpkg.json b/ports/vcpkg-pkgconfig-get-modules/vcpkg.json index f9c24c7f3623ca..3098b94f3fd7a1 100644 --- a/ports/vcpkg-pkgconfig-get-modules/vcpkg.json +++ b/ports/vcpkg-pkgconfig-get-modules/vcpkg.json @@ -1,4 +1,5 @@ { "name": "vcpkg-pkgconfig-get-modules", - "version-date": "2021-04-02" + "version-date": "2021-04-02", + "port-version": 1 } diff --git a/ports/vcpkg-pkgconfig-get-modules/x_vcpkg_pkgconfig_get_modules.cmake b/ports/vcpkg-pkgconfig-get-modules/x_vcpkg_pkgconfig_get_modules.cmake index 43ccf92e7a8c83..cfe417be0a1cd3 100644 --- a/ports/vcpkg-pkgconfig-get-modules/x_vcpkg_pkgconfig_get_modules.cmake +++ b/ports/vcpkg-pkgconfig-get-modules/x_vcpkg_pkgconfig_get_modules.cmake @@ -61,7 +61,7 @@ function(x_vcpkg_pkgconfig_get_modules) set(var_suffixes) if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release") - z_vcpkg_set_pkgconfig_path("${CURRENT_INSTALLED_DIR}/lib/pkgconfig" "${backup_PKG_CONFIG_PATH}") + z_vcpkg_set_pkgconfig_path("${CURRENT_INSTALLED_DIR}/lib/pkgconfig${VCPKG_HOST_PATH_SEPARATOR}${CURRENT_PACKAGES_DIR}/lib/pkgconfig" "${backup_PKG_CONFIG_PATH}") if(arg_LIBS) execute_process( COMMAND "${PKGCONFIG}" --libs ${arg_MODULES} @@ -96,7 +96,7 @@ function(x_vcpkg_pkgconfig_get_modules) endif() endif() if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug") - z_vcpkg_set_pkgconfig_path("${CURRENT_INSTALLED_DIR}/debug/lib/pkgconfig" "${backup_PKG_CONFIG_PATH}") + z_vcpkg_set_pkgconfig_path("${CURRENT_INSTALLED_DIR}/debug/lib/pkgconfig${VCPKG_HOST_PATH_SEPARATOR}${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig" "${backup_PKG_CONFIG_PATH}") if(arg_LIBS) execute_process( COMMAND "${PKGCONFIG}" --libs ${arg_MODULES} diff --git a/versions/a-/avcpp.json b/versions/a-/avcpp.json index f90c69a45a8603..56837510f3e241 100644 --- a/versions/a-/avcpp.json +++ b/versions/a-/avcpp.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "102cfc337c2a08e57246c399812a540315ae4531", + "version-date": "2021-05-06", + "port-version": 1 + }, { "git-tree": "aa82b322b6c59cf758147d78664f3d7ce66a77dc", "version-date": "2021-05-06", diff --git a/versions/baseline.json b/versions/baseline.json index fe9ac21df7ab24..287ffed268bb8b 100644 --- a/versions/baseline.json +++ b/versions/baseline.json @@ -218,7 +218,7 @@ }, "avcpp": { "baseline": "2021-05-06", - "port-version": 0 + "port-version": 1 }, "avisynthplus": { "baseline": "3.7.0", @@ -1978,7 +1978,7 @@ }, "ffmpeg": { "baseline": "4.4", - "port-version": 2 + "port-version": 3 }, "ffnvcodec": { "baseline": "10.0.26.0", @@ -6498,7 +6498,7 @@ }, "vcpkg-pkgconfig-get-modules": { "baseline": "2021-04-02", - "port-version": 0 + "port-version": 1 }, "vectorclass": { "baseline": "2.00.01", diff --git a/versions/f-/ffmpeg.json b/versions/f-/ffmpeg.json index 535f83e55fa3d7..ed22d7051d555d 100644 --- a/versions/f-/ffmpeg.json +++ b/versions/f-/ffmpeg.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "90a0309bd2757ee32bb13e47e07fa7b8405e6594", + "version": "4.4", + "port-version": 3 + }, { "git-tree": "998009397c4df3ca2b7d2451c9ec43c817fdc6c7", "version": "4.4", diff --git a/versions/v-/vcpkg-pkgconfig-get-modules.json b/versions/v-/vcpkg-pkgconfig-get-modules.json index c1c65a5417ae94..7a206d061cf282 100644 --- a/versions/v-/vcpkg-pkgconfig-get-modules.json +++ b/versions/v-/vcpkg-pkgconfig-get-modules.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "558512de1cc52fd9e246d6e7b99575418dd8500f", + "version-date": "2021-04-02", + "port-version": 1 + }, { "git-tree": "827541895526ebcd68711de9d05e98acd09bd323", "version-date": "2021-04-02",