X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=deps%2Flibchdr%2FCMakeLists.txt;h=5e14392beb8ad5c3e2094b6f838e4fdb5108b548;hb=e2b025820999244fbb3719530a654732643e6036;hp=9842447aec9470e71f137d0d0925e949ea97a1e4;hpb=022a8aadb40248408cefb1c8a513d23a593d6630;p=pcsx_rearmed.git diff --git a/deps/libchdr/CMakeLists.txt b/deps/libchdr/CMakeLists.txt index 9842447a..5e14392b 100644 --- a/deps/libchdr/CMakeLists.txt +++ b/deps/libchdr/CMakeLists.txt @@ -1,9 +1,6 @@ cmake_minimum_required(VERSION 3.9) -project(chdr C) - -set(CHDR_VERSION_MAJOR 0) -set(CHDR_VERSION_MINOR 1) +project(chdr VERSION 0.2 LANGUAGES C) if(CMAKE_PROJECT_NAME STREQUAL "chdr") option(BUILD_SHARED_LIBS "Build libchdr also as a shared library" ON) @@ -11,57 +8,36 @@ endif() option(INSTALL_STATIC_LIBS "Install static libraries" OFF) option(WITH_SYSTEM_ZLIB "Use system provided zlib library" OFF) -if(CMAKE_C_COMPILER_ID MATCHES "GNU") - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fvisibility=hidden -fPIC -O3 -flto") - set(CMAKE_INTERPROCEDURAL_OPTIMIZATION ON) -elseif(CMAKE_C_COMPILER_ID MATCHES "Clang") - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O3") - set(CMAKE_INTERPROCEDURAL_OPTIMIZATION OFF) +option(BUILD_LTO "Compile libchdr with link-time optimization if supported" OFF) +if(BUILD_LTO) + include(CheckIPOSupported) + check_ipo_supported(RESULT HAVE_IPO) + if(HAVE_IPO) + set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE) + endif() endif() -include(FindPkgConfig) include(GNUInstallDirs) -# Detect processor type. -if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86_64" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "amd64") - set(CPU_ARCH "x64") -elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "AMD64") - # MSVC x86/x64 - if(CMAKE_SIZEOF_VOID_P EQUAL 8) - set(CPU_ARCH "x64") - else() - set(CPU_ARCH "x86") - endif() -elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i386" OR - ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i686") - set(CPU_ARCH "x86") -elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64") - set(CPU_ARCH "aarch64") -elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv7-a") - set(CPU_ARCH "arm") -else() - message(FATAL_ERROR "Unknown system processor: " ${CMAKE_SYSTEM_PROCESSOR}) -endif() - #-------------------------------------------------- # dependencies #-------------------------------------------------- # lzma -add_subdirectory(deps/lzma-19.00 EXCLUDE_FROM_ALL) +add_subdirectory(deps/lzma-22.01 EXCLUDE_FROM_ALL) list(APPEND CHDR_LIBS lzma) list(APPEND CHDR_INCLUDES lzma) # zlib if (WITH_SYSTEM_ZLIB) - pkg_check_modules(ZLIB REQUIRED zlib) - list(APPEND PLATFORM_INCLUDES ${ZLIB_INCLUDE_DIRS}) - list(APPEND PLATFORM_LIBS ${ZLIB_LIBRARIES}) + find_package(ZLIB REQUIRED) + list(APPEND PLATFORM_LIBS ZLIB::ZLIB) else() - add_subdirectory(deps/zlib-1.2.11 EXCLUDE_FROM_ALL) - list(APPEND CHDR_LIBS zlib) - list(APPEND CHDR_INCLUDES zlib) + add_subdirectory(deps/zlib-1.2.13 EXCLUDE_FROM_ALL) + set_target_properties(zlibstatic PROPERTIES POSITION_INDEPENDENT_CODE ON) + list(APPEND CHDR_LIBS zlibstatic) + list(APPEND CHDR_INCLUDES "${CMAKE_CURRENT_SOURCE_DIR}/deps/zlib-1.2.13" "${CMAKE_CURRENT_BINARY_DIR}/deps/zlib-1.2.13") endif() #-------------------------------------------------- @@ -79,10 +55,13 @@ set(CHDR_SOURCES list(APPEND CHDR_INCLUDES ${CMAKE_CURRENT_BINARY_DIR}/include) add_library(chdr-static STATIC ${CHDR_SOURCES}) -target_include_directories(chdr-static PRIVATE ${CHDR_INCLUDES} ${PLATFORM_INCLUDES} PUBLIC include) -target_compile_definitions(chdr-static PRIVATE ${CHDR_DEFS}) +target_include_directories(chdr-static PRIVATE ${CHDR_INCLUDES} PUBLIC include) target_link_libraries(chdr-static PRIVATE ${CHDR_LIBS} ${PLATFORM_LIBS}) +if(MSVC) + target_compile_definitions(chdr-static PRIVATE _CRT_SECURE_NO_WARNINGS) +endif() + if (INSTALL_STATIC_LIBS) install(TARGETS chdr-static ${CHDR_LIBS} ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}" @@ -90,25 +69,24 @@ if (INSTALL_STATIC_LIBS) endif() if (BUILD_SHARED_LIBS) - set(CMAKE_CXX_VISIBILITY_PRESET hidden) - set(CMAKE_VISIBILITY_INLINES_HIDDEN 1) - add_library(chdr SHARED ${CHDR_SOURCES}) - target_include_directories(chdr PRIVATE ${CHDR_INCLUDES} ${PLATFORM_INCLUDES} PUBLIC include) - target_compile_definitions(chdr PRIVATE ${CHDR_DEFS}) + target_include_directories(chdr PRIVATE ${CHDR_INCLUDES} PUBLIC include) target_link_libraries(chdr PRIVATE ${CHDR_LIBS} ${PLATFORM_LIBS}) if(MSVC) target_compile_definitions(chdr PUBLIC "CHD_DLL") target_compile_definitions(chdr PRIVATE "CHD_DLL_EXPORTS") + target_compile_definitions(chdr PRIVATE _CRT_SECURE_NO_WARNINGS) elseif(APPLE) - target_link_options(chdr PRIVATE -Wl,-dead_strip -Wl,-exported_symbol,_chd_*) + target_link_libraries(chdr PRIVATE -Wl,-dead_strip -Wl,-exported_symbol,_chd_*) else() - target_link_options(chdr PRIVATE -Wl,--version-script ${CMAKE_CURRENT_SOURCE_DIR}/src/link.T -Wl,--no-undefined) + target_link_libraries(chdr PRIVATE -Wl,--version-script ${CMAKE_CURRENT_SOURCE_DIR}/src/link.T -Wl,--no-undefined) endif() + set_target_properties(chdr PROPERTIES C_VISIBILITY_PRESET hidden) + set_target_properties(chdr PROPERTIES VISIBILITY_INLINES_HIDDEN 1) set_target_properties(chdr PROPERTIES PUBLIC_HEADER "include/libchdr/bitstream.h;include/libchdr/cdrom.h;include/libchdr/chd.h;include/libchdr/chdconfig.h;include/libchdr/coretypes.h;include/libchdr/flac.h;include/libchdr/huffman.h") - set_target_properties(chdr PROPERTIES VERSION "${CHDR_VERSION_MAJOR}.${CHDR_VERSION_MINOR}") + set_target_properties(chdr PROPERTIES VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}" SOVERSION ${PROJECT_VERSION_MAJOR}) if (CMAKE_BUILD_TYPE MATCHES Release) #add_custom_command(TARGET chdr POST_BUILD COMMAND ${CMAKE_STRIP} libchdr.so) @@ -124,3 +102,4 @@ if (BUILD_SHARED_LIBS) install(FILES ${CMAKE_BINARY_DIR}/libchdr.pc DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig") endif() +add_subdirectory(tests)