Merge pull request #8624 from lat9nq/vcpkg
ci,CMake: Drop Conan support for vcpkg
This commit is contained in:
		| @@ -6,7 +6,17 @@ set -e | ||||
| ccache -s | ||||
|  | ||||
| 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" \ | ||||
|       -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 | ||||
|  | ||||
|   | ||||
| @@ -6,10 +6,6 @@ set -e | ||||
|  | ||||
| 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 | ||||
| export LDFLAGS="-fuse-ld=lld" | ||||
| # -femulated-tls required due to an incompatibility between GCC and Clang | ||||
| @@ -24,6 +20,7 @@ cmake .. \ | ||||
|     -DUSE_CCACHE=ON \ | ||||
|     -DYUZU_USE_BUNDLED_SDL2=OFF \ | ||||
|     -DYUZU_USE_EXTERNAL_SDL2=OFF \ | ||||
|     -DYUZU_TESTS=OFF \ | ||||
|     -GNinja | ||||
| ninja yuzu yuzu-cmd | ||||
|  | ||||
|   | ||||
| @@ -6,9 +6,7 @@ parameters: | ||||
| steps: | ||||
| - script: choco install vulkan-sdk | ||||
|   displayName: 'Install vulkan-sdk' | ||||
| - script: python -m pip install --upgrade pip conan | ||||
|   displayName: 'Install conan' | ||||
| - script: refreshenv && mkdir build && cd build && cmake -G "Visual Studio 17 2022" -A x64 -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=${COMPAT} -DYUZU_TESTS=OFF -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DDISPLAY_VERSION=${{ parameters['version'] }} -DCMAKE_BUILD_TYPE=Release .. && cd .. | ||||
| - script: refreshenv && mkdir build && cd build && cmake -G "Visual Studio 17 2022" -A x64 -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=${COMPAT} -DYUZU_TESTS=OFF -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DDISPLAY_VERSION=${{ parameters['version'] }} -DCMAKE_BUILD_TYPE=Release -DYUZU_TESTS=OFF -DYUZU_USE_BUNDLED_VCPKG=ON .. && cd .. | ||||
|   displayName: 'Configure CMake' | ||||
| - task: MSBuild@1 | ||||
|   displayName: 'Build' | ||||
|   | ||||
							
								
								
									
										3
									
								
								.github/workflows/verify.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/verify.yml
									
									
									
									
										vendored
									
									
								
							| @@ -80,7 +80,6 @@ jobs: | ||||
|         shell: cmd | ||||
|         run: | | ||||
|           choco install vulkan-sdk wget | ||||
|           python -m pip install --upgrade pip conan | ||||
|           call refreshenv | ||||
|           wget https://github.com/mbitsnbites/buildcache/releases/download/v0.27.6/buildcache-windows.zip | ||||
|           7z x buildcache-windows.zip | ||||
| @@ -100,7 +99,7 @@ jobs: | ||||
|         run: | | ||||
|           glslangValidator --version | ||||
|           mkdir build | ||||
|           cmake . -B build -GNinja -DCMAKE_TOOLCHAIN_FILE="CMakeModules/MSVCCache.cmake" -DUSE_CCACHE=ON -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=ON -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DCMAKE_BUILD_TYPE=Release | ||||
|           cmake . -B build -GNinja -DCMAKE_TOOLCHAIN_FILE="CMakeModules/MSVCCache.cmake" -DUSE_CCACHE=ON -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=ON -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DCMAKE_BUILD_TYPE=Release -DYUZU_TESTS=OFF -DYUZU_USE_BUNDLED_VCPKG=ON | ||||
|       - name: Build | ||||
|         run: cmake --build build | ||||
|       - name: Cache Summary | ||||
|   | ||||
							
								
								
									
										7
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -34,9 +34,12 @@ | ||||
| [submodule "SDL"] | ||||
| 	path = externals/SDL | ||||
| 	url = https://github.com/libsdl-org/SDL.git | ||||
| [submodule "externals/cpp-httplib"] | ||||
| [submodule "cpp-httplib"] | ||||
| 	path = externals/cpp-httplib | ||||
| 	url = https://github.com/yhirose/cpp-httplib.git | ||||
| [submodule "externals/ffmpeg/ffmpeg"] | ||||
| [submodule "ffmpeg"] | ||||
| 	path = externals/ffmpeg/ffmpeg | ||||
| 	url = https://git.ffmpeg.org/ffmpeg.git | ||||
| [submodule "vcpkg"] | ||||
| 	path = externals/vcpkg | ||||
| 	url = https://github.com/Microsoft/vcpkg.git | ||||
|   | ||||
							
								
								
									
										170
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
							
						
						
									
										170
									
								
								CMakeLists.txt
									
									
									
									
									
								
							| @@ -35,6 +35,16 @@ option(YUZU_USE_BUNDLED_OPUS "Compile bundled opus" ON) | ||||
|  | ||||
| option(YUZU_TESTS "Compile tests" ON) | ||||
|  | ||||
| option(YUZU_USE_BUNDLED_VCPKG "Use vcpkg for yuzu dependencies" OFF) | ||||
|  | ||||
| if (YUZU_USE_BUNDLED_VCPKG) | ||||
|     include(${CMAKE_SOURCE_DIR}/externals/vcpkg/scripts/buildsystems/vcpkg.cmake) | ||||
| elseif(NOT "$ENV{VCPKG_TOOLCHAIN_FILE}" STREQUAL "") | ||||
|     # Disable manifest mode (use vcpkg classic mode) when using a custom vcpkg installation | ||||
|     option(VCPKG_MANIFEST_MODE "") | ||||
|     include("$ENV{VCPKG_TOOLCHAIN_FILE}") | ||||
| endif() | ||||
|  | ||||
| # Default to a Release build | ||||
| get_property(IS_MULTI_CONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) | ||||
| if (NOT IS_MULTI_CONFIG AND NOT CMAKE_BUILD_TYPE) | ||||
| @@ -144,82 +154,34 @@ endif() | ||||
| set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/bin) | ||||
|  | ||||
| # System imported libraries | ||||
| # If not found, download any missing through Conan | ||||
| # ======================================================================= | ||||
| set(CONAN_CMAKE_SILENT_OUTPUT TRUE) | ||||
| set(CMAKE_FIND_PACKAGE_PREFER_CONFIG TRUE) | ||||
| if (YUZU_CONAN_INSTALLED) | ||||
|     if (IS_MULTI_CONFIG) | ||||
|         include(${CMAKE_BINARY_DIR}/conanbuildinfo_multi.cmake) | ||||
|     else() | ||||
|         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() | ||||
|     message(STATUS "Adding conan installed libraries to the search path") | ||||
|  | ||||
| find_package(fmt 8.0.1 REQUIRED CONFIG) | ||||
| find_package(lz4 1.8 REQUIRED) | ||||
| find_package(nlohmann_json 3.8 REQUIRED CONFIG) | ||||
| find_package(ZLIB 1.2 REQUIRED) | ||||
|  | ||||
| # Search for config-only package first (for vcpkg), then try non-config | ||||
| find_package(zstd 1.5 CONFIG) | ||||
| if (NOT zstd_FOUND) | ||||
|     find_package(zstd 1.5 REQUIRED) | ||||
| endif() | ||||
|  | ||||
| macro(yuzu_find_packages) | ||||
|     set(options FORCE_REQUIRED) | ||||
|     cmake_parse_arguments(FN "${options}" "" "" ${ARGN}) | ||||
| if (YUZU_TESTS) | ||||
|     find_package(Catch2 2.13.7 REQUIRED CONFIG) | ||||
| endif() | ||||
|  | ||||
|     # Cmake has a *serious* lack of 2D array or associative array... | ||||
|     # 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) | ||||
| find_package(Boost 1.73.0 COMPONENTS context) | ||||
| if (Boost_FOUND) | ||||
|     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 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) | ||||
|         list(APPEND Boost_LIBRARIES Boost::context) | ||||
|     endif() | ||||
| else() | ||||
|     message(STATUS "Boost 1.79.0 or newer not found, falling back to Conan") | ||||
|     list(APPEND CONAN_REQUIRED_LIBS "boost/1.79.0") | ||||
|     message(FATAL_ERROR "Boost 1.73.0 or newer not found") | ||||
| endif() | ||||
|  | ||||
| # boost:asio has functions that require AcceptEx et al | ||||
| @@ -227,19 +189,9 @@ if (MINGW) | ||||
|     find_library(MSWSOCK_LIBRARY mswsock REQUIRED) | ||||
| 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 | ||||
| if(ENABLE_QT) | ||||
|     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 | ||||
|     if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") | ||||
| @@ -330,9 +282,6 @@ if(ENABLE_QT) | ||||
|  | ||||
|     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 ((MSVC_VERSION GREATER_EQUAL 1920 AND MSVC_VERSION LESS 1940) AND ARCHITECTURE_x86_64) | ||||
|             set(QT_BUILD qt-5.15.2-msvc2019_64) | ||||
| @@ -403,71 +352,8 @@ if (ENABLE_SDL2) | ||||
|     endif() | ||||
| endif() | ||||
|  | ||||
| # Install any missing dependencies with conan install | ||||
| 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() | ||||
|  | ||||
| # TODO(lat9nq): Determine what if any of this we still need | ||||
| # | ||||
| # 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 | ||||
| # Dynarmic checks for target `boost` and so we want to make sure it can find it through our system instead of using their external | ||||
|   | ||||
							
								
								
									
										1
									
								
								externals/vcpkg
									
									
									
									
										vendored
									
									
										Submodule
									
								
							
							
								
								
								
								
								
							
						
						
									
										1
									
								
								externals/vcpkg
									
									
									
									
										vendored
									
									
										Submodule
									
								
							 Submodule externals/vcpkg added at cef0b3ec76
									
								
							| @@ -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 PRIVATE lz4::lz4 xbyak) | ||||
| if (MSVC) | ||||
| if (TARGET zstd::zstd) | ||||
|   target_link_libraries(common PRIVATE zstd::zstd) | ||||
| 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() | ||||
|   | ||||
							
								
								
									
										29
									
								
								vcpkg.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vcpkg.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| { | ||||
|     "$schema": "https://raw.githubusercontent.com/microsoft/vcpkg/master/scripts/vcpkg.schema.json", | ||||
|     "name": "yuzu", | ||||
|     "version": "1.0", | ||||
|     "dependencies": [ | ||||
|         "boost-algorithm", | ||||
|         "boost-asio", | ||||
|         "boost-bind", | ||||
|         "boost-config", | ||||
|         "boost-container", | ||||
|         "boost-context", | ||||
|         "boost-crc", | ||||
|         "boost-functional", | ||||
|         "boost-icl", | ||||
|         "boost-intrusive", | ||||
|         "boost-mpl", | ||||
|         "boost-process", | ||||
|         "boost-range", | ||||
|         "boost-spirit", | ||||
|         "boost-test", | ||||
|         "boost-timer", | ||||
|         "boost-variant", | ||||
|         "fmt", | ||||
|         "lz4", | ||||
|         "nlohmann-json", | ||||
|         "zlib", | ||||
|         "zstd" | ||||
|     ] | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 bunnei
					bunnei