mirror of
https://git.h3cjp.net/H3cJP/yuzu.git
synced 2024-11-15 04:22:47 +00:00
ci,CMake: Drop Conan support for vcpkg
Between packages breaking, Conan always being a moving target for minimum required CMake support, and now their moves to Conan 2.0 causing existing packages to break, I suppose this was a long time coming. vcpkg isn't without its drawbacks, but at the moment it seems easier on the project to use for external packages. Mostly removes the logic for Conan from the root CMakeLists file, leaving basic find_package()'s in its place. Sets only the find_package()'s that require CONFIG mode as necessary. clang and linux CI now use the vcpkg toolchain file configured in the Docker container when possible. mingw CI turns off YUZU_TESTS because there's no way on the container to run Windows executables on a Linux host anyway, and it's not easy to get Catch2 there.
This commit is contained in:
parent
6e36f4d230
commit
4b93ea59db
|
@ -6,7 +6,18 @@ set -e
|
||||||
ccache -s
|
ccache -s
|
||||||
|
|
||||||
mkdir build || true && cd build
|
mkdir build || true && cd build
|
||||||
cmake .. -GNinja -DDISPLAY_VERSION=$1 -DCMAKE_BUILD_TYPE=Release -DCMAKE_C_COMPILER=/usr/lib/ccache/clang -DCMAKE_CXX_COMPILER=/usr/lib/ccache/clang++ -DYUZU_ENABLE_COMPATIBILITY_REPORTING=${ENABLE_COMPATIBILITY_REPORTING:-"OFF"} -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DCMAKE_INSTALL_PREFIX="/usr"
|
cmake .. \
|
||||||
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
|
-DCMAKE_CXX_COMPILER=/usr/lib/ccache/clang++ \
|
||||||
|
-DCMAKE_C_COMPILER=/usr/lib/ccache/clang \
|
||||||
|
-DCMAKE_INSTALL_PREFIX="/usr" \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE=${VCPKG_TOOLCHAIN_FILE} \
|
||||||
|
-DDISPLAY_VERSION=$1 \
|
||||||
|
-DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON \
|
||||||
|
-DENABLE_QT_TRANSLATION=ON \
|
||||||
|
-DUSE_DISCORD_PRESENCE=ON \
|
||||||
|
-DYUZU_ENABLE_COMPATIBILITY_REPORTING=${ENABLE_COMPATIBILITY_REPORTING:-"OFF"} \
|
||||||
|
-GNinja
|
||||||
|
|
||||||
ninja
|
ninja
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@ cmake .. \
|
||||||
-DCMAKE_CXX_COMPILER=/usr/lib/ccache/g++ \
|
-DCMAKE_CXX_COMPILER=/usr/lib/ccache/g++ \
|
||||||
-DCMAKE_C_COMPILER=/usr/lib/ccache/gcc \
|
-DCMAKE_C_COMPILER=/usr/lib/ccache/gcc \
|
||||||
-DCMAKE_INSTALL_PREFIX="/usr" \
|
-DCMAKE_INSTALL_PREFIX="/usr" \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE=${VCPKG_TOOLCHAIN_FILE} \
|
||||||
-DDISPLAY_VERSION=$1 \
|
-DDISPLAY_VERSION=$1 \
|
||||||
-DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON \
|
-DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON \
|
||||||
-DENABLE_QT_TRANSLATION=ON \
|
-DENABLE_QT_TRANSLATION=ON \
|
||||||
|
|
|
@ -6,10 +6,6 @@ set -e
|
||||||
|
|
||||||
ccache -sv
|
ccache -sv
|
||||||
|
|
||||||
mkdir -p "$HOME/.conan/profiles"
|
|
||||||
wget -c "https://github.com/yuzu-emu/build-environments/raw/master/linux-mingw/default" -O "$HOME/.conan/profiles/default"
|
|
||||||
wget -c "https://github.com/yuzu-emu/build-environments/raw/master/linux-mingw/settings.yml" -O "$HOME/.conan/settings.yml"
|
|
||||||
|
|
||||||
mkdir -p build && cd build
|
mkdir -p build && cd build
|
||||||
export LDFLAGS="-fuse-ld=lld"
|
export LDFLAGS="-fuse-ld=lld"
|
||||||
# -femulated-tls required due to an incompatibility between GCC and Clang
|
# -femulated-tls required due to an incompatibility between GCC and Clang
|
||||||
|
@ -24,6 +20,7 @@ cmake .. \
|
||||||
-DUSE_CCACHE=ON \
|
-DUSE_CCACHE=ON \
|
||||||
-DYUZU_USE_BUNDLED_SDL2=OFF \
|
-DYUZU_USE_BUNDLED_SDL2=OFF \
|
||||||
-DYUZU_USE_EXTERNAL_SDL2=OFF \
|
-DYUZU_USE_EXTERNAL_SDL2=OFF \
|
||||||
|
-DYUZU_TESTS=OFF \
|
||||||
-GNinja
|
-GNinja
|
||||||
ninja yuzu yuzu-cmd
|
ninja yuzu yuzu-cmd
|
||||||
|
|
||||||
|
|
160
CMakeLists.txt
160
CMakeLists.txt
|
@ -144,82 +144,34 @@ endif()
|
||||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/bin)
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/bin)
|
||||||
|
|
||||||
# System imported libraries
|
# System imported libraries
|
||||||
# If not found, download any missing through Conan
|
|
||||||
# =======================================================================
|
# =======================================================================
|
||||||
set(CONAN_CMAKE_SILENT_OUTPUT TRUE)
|
|
||||||
set(CMAKE_FIND_PACKAGE_PREFER_CONFIG TRUE)
|
find_package(fmt 8.0.1 REQUIRED CONFIG)
|
||||||
if (YUZU_CONAN_INSTALLED)
|
find_package(lz4 1.8 REQUIRED)
|
||||||
if (IS_MULTI_CONFIG)
|
find_package(nlohmann_json 3.8 REQUIRED CONFIG)
|
||||||
include(${CMAKE_BINARY_DIR}/conanbuildinfo_multi.cmake)
|
find_package(ZLIB 1.2 REQUIRED)
|
||||||
else()
|
|
||||||
include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
|
# Search for config-only package first (for vcpkg), then try non-config
|
||||||
endif()
|
find_package(zstd 1.5 CONFIG)
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_BINARY_DIR}")
|
if (NOT zstd_FOUND)
|
||||||
list(APPEND CMAKE_PREFIX_PATH "${CMAKE_BINARY_DIR}")
|
find_package(zstd 1.5 REQUIRED)
|
||||||
conan_basic_setup()
|
|
||||||
message(STATUS "Adding conan installed libraries to the search path")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
macro(yuzu_find_packages)
|
if (YUZU_TESTS)
|
||||||
set(options FORCE_REQUIRED)
|
find_package(Catch2 2.13.7 REQUIRED CONFIG)
|
||||||
cmake_parse_arguments(FN "${options}" "" "" ${ARGN})
|
endif()
|
||||||
|
|
||||||
# Cmake has a *serious* lack of 2D array or associative array...
|
find_package(Boost 1.73.0 COMPONENTS context)
|
||||||
# Capitalization matters here. We need the naming to match the generated paths from Conan
|
|
||||||
set(REQUIRED_LIBS
|
|
||||||
# Cmake Pkg Prefix Version Conan Pkg
|
|
||||||
"fmt 8.0.1 fmt/8.1.1"
|
|
||||||
"lz4 1.8 lz4/1.9.2"
|
|
||||||
"nlohmann_json 3.8 nlohmann_json/3.8.0"
|
|
||||||
"ZLIB 1.2 zlib/1.2.11"
|
|
||||||
"zstd 1.5 zstd/1.5.0"
|
|
||||||
# can't use opus until AVX check is fixed: https://github.com/yuzu-emu/yuzu/pull/4068
|
|
||||||
#"opus 1.3 opus/1.3.1"
|
|
||||||
)
|
|
||||||
if (YUZU_TESTS)
|
|
||||||
list(APPEND REQUIRED_LIBS
|
|
||||||
"Catch2 2.13.7 catch2/2.13.7"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
foreach(PACKAGE ${REQUIRED_LIBS})
|
|
||||||
string(REGEX REPLACE "[ \t\r\n]+" ";" PACKAGE_SPLIT ${PACKAGE})
|
|
||||||
list(GET PACKAGE_SPLIT 0 PACKAGE_PREFIX)
|
|
||||||
list(GET PACKAGE_SPLIT 1 PACKAGE_VERSION)
|
|
||||||
list(GET PACKAGE_SPLIT 2 PACKAGE_CONAN)
|
|
||||||
# This function is called twice, once to check if the packages exist on the system already
|
|
||||||
# and a second time to check if conan installed them properly. The second check passes in FORCE_REQUIRED
|
|
||||||
if (NOT ${PACKAGE_PREFIX}_FOUND)
|
|
||||||
if (FN_FORCE_REQUIRED)
|
|
||||||
find_package(${PACKAGE_PREFIX} ${PACKAGE_VERSION} REQUIRED)
|
|
||||||
else()
|
|
||||||
find_package(${PACKAGE_PREFIX} ${PACKAGE_VERSION})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
if (NOT ${PACKAGE_PREFIX}_FOUND)
|
|
||||||
list(APPEND CONAN_REQUIRED_LIBS ${PACKAGE_CONAN})
|
|
||||||
else()
|
|
||||||
# Set a legacy findPackage.cmake style PACKAGE_LIBRARIES variable for subprojects that rely on this
|
|
||||||
set(${PACKAGE_PREFIX}_LIBRARIES "${PACKAGE_PREFIX}::${PACKAGE_PREFIX}")
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
unset(FN_FORCE_REQUIRED)
|
|
||||||
endmacro()
|
|
||||||
|
|
||||||
find_package(Boost 1.73.0 COMPONENTS context headers)
|
|
||||||
if (Boost_FOUND)
|
if (Boost_FOUND)
|
||||||
set(Boost_LIBRARIES Boost::boost)
|
set(Boost_LIBRARIES Boost::boost)
|
||||||
# Conditionally add Boost::context only if the active version of the Conan or system Boost package provides it
|
# Conditionally add Boost::context only if the found Boost package provides it
|
||||||
# The old version is missing Boost::context, so we want to avoid adding in that case
|
# The old version is missing Boost::context, so we want to avoid adding in that case
|
||||||
# The new version requires adding Boost::context to prevent linking issues
|
# The new version requires adding Boost::context to prevent linking issues
|
||||||
#
|
|
||||||
# This one is used by Conan on subsequent CMake configures, not the first configure.
|
|
||||||
if (TARGET Boost::context)
|
if (TARGET Boost::context)
|
||||||
list(APPEND Boost_LIBRARIES Boost::context)
|
list(APPEND Boost_LIBRARIES Boost::context)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
message(STATUS "Boost 1.79.0 or newer not found, falling back to Conan")
|
message(FATAL_ERROR "Boost 1.73.0 or newer not found")
|
||||||
list(APPEND CONAN_REQUIRED_LIBS "boost/1.79.0")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# boost:asio has functions that require AcceptEx et al
|
# boost:asio has functions that require AcceptEx et al
|
||||||
|
@ -227,19 +179,9 @@ if (MINGW)
|
||||||
find_library(MSWSOCK_LIBRARY mswsock REQUIRED)
|
find_library(MSWSOCK_LIBRARY mswsock REQUIRED)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Attempt to locate any packages that are required and report the missing ones in CONAN_REQUIRED_LIBS
|
|
||||||
yuzu_find_packages()
|
|
||||||
|
|
||||||
# Qt5 requires that we find components, so it doesn't fit our pretty little find package function
|
# Qt5 requires that we find components, so it doesn't fit our pretty little find package function
|
||||||
if(ENABLE_QT)
|
if(ENABLE_QT)
|
||||||
set(QT_VERSION 5.15)
|
set(QT_VERSION 5.15)
|
||||||
# We want to load the generated conan qt config so that we get the QT_ROOT var so that we can use the official
|
|
||||||
# Qt5Config inside the root folder instead of the conan generated one.
|
|
||||||
if(EXISTS ${CMAKE_BINARY_DIR}/qtConfig.cmake)
|
|
||||||
include(${CMAKE_BINARY_DIR}/qtConfig.cmake)
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CONAN_QT_ROOT_RELEASE}")
|
|
||||||
list(APPEND CMAKE_PREFIX_PATH "${CONAN_QT_ROOT_RELEASE}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for system Qt on Linux, fallback to bundled Qt
|
# Check for system Qt on Linux, fallback to bundled Qt
|
||||||
if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
|
if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
|
||||||
|
@ -330,9 +272,6 @@ if(ENABLE_QT)
|
||||||
|
|
||||||
set(YUZU_QT_NO_CMAKE_SYSTEM_PATH)
|
set(YUZU_QT_NO_CMAKE_SYSTEM_PATH)
|
||||||
|
|
||||||
# Workaround for an issue where conan tries to build Qt from scratch instead of download prebuilt binaries
|
|
||||||
set(QT_PREFIX_HINT)
|
|
||||||
|
|
||||||
if(YUZU_USE_BUNDLED_QT)
|
if(YUZU_USE_BUNDLED_QT)
|
||||||
if ((MSVC_VERSION GREATER_EQUAL 1920 AND MSVC_VERSION LESS 1940) AND ARCHITECTURE_x86_64)
|
if ((MSVC_VERSION GREATER_EQUAL 1920 AND MSVC_VERSION LESS 1940) AND ARCHITECTURE_x86_64)
|
||||||
set(QT_BUILD qt-5.15.2-msvc2019_64)
|
set(QT_BUILD qt-5.15.2-msvc2019_64)
|
||||||
|
@ -403,71 +342,8 @@ if (ENABLE_SDL2)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Install any missing dependencies with conan install
|
# TODO(lat9nq): Determine what if any of this we still need
|
||||||
if (CONAN_REQUIRED_LIBS)
|
#
|
||||||
message(STATUS "Packages ${CONAN_REQUIRED_LIBS} not found!")
|
|
||||||
# Use Conan to fetch the libraries that aren't found
|
|
||||||
# Download conan.cmake automatically, you can also just copy the conan.cmake file
|
|
||||||
if(NOT EXISTS "${CMAKE_BINARY_DIR}/conan.cmake")
|
|
||||||
message(STATUS "Downloading conan.cmake from https://github.com/conan-io/cmake-conan")
|
|
||||||
file(DOWNLOAD "https://raw.githubusercontent.com/conan-io/cmake-conan/release/0.18/conan.cmake" "${CMAKE_BINARY_DIR}/conan.cmake")
|
|
||||||
endif()
|
|
||||||
include(${CMAKE_BINARY_DIR}/conan.cmake)
|
|
||||||
|
|
||||||
conan_check(VERSION 1.45.0 REQUIRED)
|
|
||||||
|
|
||||||
# Manually add iconv to fix a dep conflict between qt and sdl2
|
|
||||||
# We don't need to add it through find_package or anything since the other two can find it just fine
|
|
||||||
if ("${CONAN_REQUIRED_LIBS}" MATCHES "qt" AND "${CONAN_REQUIRED_LIBS}" MATCHES "sdl")
|
|
||||||
list(APPEND CONAN_REQUIRED_LIBS "libiconv/1.16")
|
|
||||||
endif()
|
|
||||||
if (IS_MULTI_CONFIG)
|
|
||||||
conan_cmake_run(REQUIRES ${CONAN_REQUIRED_LIBS}
|
|
||||||
OPTIONS ${CONAN_LIB_OPTIONS}
|
|
||||||
BUILD missing
|
|
||||||
CONFIGURATION_TYPES "Release;Debug"
|
|
||||||
GENERATORS cmake_multi cmake_find_package_multi)
|
|
||||||
include(${CMAKE_BINARY_DIR}/conanbuildinfo_multi.cmake)
|
|
||||||
else()
|
|
||||||
conan_cmake_run(REQUIRES ${CONAN_REQUIRED_LIBS}
|
|
||||||
OPTIONS ${CONAN_LIB_OPTIONS}
|
|
||||||
BUILD missing
|
|
||||||
GENERATORS cmake cmake_find_package_multi)
|
|
||||||
include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
|
|
||||||
endif()
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_BINARY_DIR}")
|
|
||||||
list(APPEND CMAKE_PREFIX_PATH "${CMAKE_BINARY_DIR}")
|
|
||||||
conan_basic_setup()
|
|
||||||
|
|
||||||
set(YUZU_CONAN_INSTALLED TRUE CACHE BOOL "If true, the following builds will add conan to the lib search path" FORCE)
|
|
||||||
|
|
||||||
# Now that we've installed what we are missing, try to locate them again,
|
|
||||||
# this time with required, so we bail if its not found.
|
|
||||||
yuzu_find_packages(FORCE_REQUIRED)
|
|
||||||
|
|
||||||
if (NOT Boost_FOUND)
|
|
||||||
find_package(Boost 1.73.0 REQUIRED COMPONENTS context headers)
|
|
||||||
set(Boost_LIBRARIES Boost::boost)
|
|
||||||
# Conditionally add Boost::context only if the active version of the Conan Boost package provides it
|
|
||||||
# The old version is missing Boost::context, so we want to avoid adding in that case
|
|
||||||
# The new version requires adding Boost::context to prevent linking issues
|
|
||||||
if (TARGET Boost::context)
|
|
||||||
list(APPEND Boost_LIBRARIES Boost::context)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Due to issues with variable scopes in functions, we need to also find_package(qt5) outside of the function
|
|
||||||
if(ENABLE_QT)
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CONAN_QT_ROOT_RELEASE}")
|
|
||||||
list(APPEND CMAKE_PREFIX_PATH "${CONAN_QT_ROOT_RELEASE}")
|
|
||||||
find_package(Qt5 5.15 REQUIRED COMPONENTS Widgets)
|
|
||||||
if (YUZU_USE_QT_WEB_ENGINE)
|
|
||||||
find_package(Qt5 REQUIRED COMPONENTS WebEngineCore WebEngineWidgets)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Reexport some targets that are named differently when using the upstream CmakeConfig vs the generated Conan config
|
# Reexport some targets that are named differently when using the upstream CmakeConfig vs the generated Conan config
|
||||||
# In order to ALIAS targets to a new name, they first need to be IMPORTED_GLOBAL
|
# In order to ALIAS targets to a new name, they first need to be IMPORTED_GLOBAL
|
||||||
# Dynarmic checks for target `boost` and so we want to make sure it can find it through our system instead of using their external
|
# Dynarmic checks for target `boost` and so we want to make sure it can find it through our system instead of using their external
|
||||||
|
|
|
@ -182,8 +182,9 @@ create_target_directory_groups(common)
|
||||||
|
|
||||||
target_link_libraries(common PUBLIC ${Boost_LIBRARIES} fmt::fmt microprofile Threads::Threads)
|
target_link_libraries(common PUBLIC ${Boost_LIBRARIES} fmt::fmt microprofile Threads::Threads)
|
||||||
target_link_libraries(common PRIVATE lz4::lz4 xbyak)
|
target_link_libraries(common PRIVATE lz4::lz4 xbyak)
|
||||||
if (MSVC)
|
if (TARGET zstd::zstd)
|
||||||
target_link_libraries(common PRIVATE zstd::zstd)
|
target_link_libraries(common PRIVATE zstd::zstd)
|
||||||
else()
|
else()
|
||||||
target_link_libraries(common PRIVATE zstd)
|
target_link_libraries(common PRIVATE
|
||||||
|
$<IF:$<TARGET_EXISTS:zstd::libzstd_shared>,zstd::libzstd_shared,zstd::libzstd_static>)
|
||||||
endif()
|
endif()
|
||||||
|
|
Loading…
Reference in a new issue