From 189f56edaa6949c156acc0840c48d1ff38edf481 Mon Sep 17 00:00:00 2001 From: zhaozg Date: Wed, 10 Jul 2024 15:27:22 +0800 Subject: [PATCH] cmake: new option BUILD_NO_STDIO to enable MINIZ_NO_STDIO --- CMakeLists.txt | 54 +++++++++++++++++++++++++++++--------------------- tests/main.cpp | 6 +++++- 2 files changed, 36 insertions(+), 24 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 8978910..93ab058 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -26,7 +26,7 @@ endif() set(MINIZ_API_VERSION 3) set(MINIZ_MINOR_VERSION 0) set(MINIZ_PATCH_VERSION 2) -set(MINIZ_VERSION +set(MINIZ_VERSION ${MINIZ_API_VERSION}.${MINIZ_MINOR_VERSION}.${MINIZ_PATCH_VERSION}) if(CMAKE_BUILD_TYPE STREQUAL "") @@ -42,6 +42,7 @@ option(BUILD_FUZZERS "Build fuzz targets" OFF) option(AMALGAMATE_SOURCES "Amalgamate sources into miniz.h/c" OFF) option(BUILD_HEADER_ONLY "Build a header-only version" OFF) option(BUILD_SHARED_LIBS "Build shared library instead of static" OFF) +option(BUILD_NO_STDIO" Build a without stdio version" OFF) option(BUILD_TESTS "Build tests" ${MINIZ_STANDALONE_PROJECT}) option(INSTALL_PROJECT "Install project" ${MINIZ_STANDALONE_PROJECT}) @@ -85,14 +86,14 @@ if(AMALGAMATE_SOURCES) "${AMAL_MINIZ_C}" "\n#endif // MINIZ_HEADER_FILE_ONLY\n") file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/amalgamation/miniz.h "${AMAL_MINIZ_H}") add_library(${PROJECT_NAME} INTERFACE) - + # Might not be a good idea to force this on the library user # as it could bloat the global namespace # https://github.com/libevent/libevent/issues/460 - # target_compile_definitions(${PROJECT_NAME} + # target_compile_definitions(${PROJECT_NAME} # INTERFACE $<$:_GNU_SOURCE>) - - set_property(TARGET ${PROJECT_NAME} APPEND + + set_property(TARGET ${PROJECT_NAME} APPEND PROPERTY INTERFACE_INCLUDE_DIRECTORIES $ $ @@ -111,7 +112,7 @@ if(AMALGAMATE_SOURCES) endif(BUILD_HEADER_ONLY) set(INSTALL_HEADERS ${CMAKE_CURRENT_BINARY_DIR}/amalgamation/miniz.h) - + file(GLOB_RECURSE ZIP_FILES RELATIVE "${CMAKE_CURRENT_BINARY_DIR}/amalgamation" "${CMAKE_CURRENT_BINARY_DIR}/amalgamation/*") file(GLOB_RECURSE ZIP_FILES2 RELATIVE "${CMAKE_SOURCE_DIR}" "${CMAKE_SOURCE_DIR}/examples/*") list(APPEND ZIP_FILES ${ZIP_FILES2}) @@ -131,7 +132,7 @@ if(AMALGAMATE_SOURCES) DEPENDS ${ZIP_FILES} COMMENT "Zipping to ${CMAKE_CURRENT_BINARY_DIR}/miniz.zip." ) - + add_custom_target( create_zip ALL DEPENDS "${ZIP_OUT_FN}" @@ -152,20 +153,20 @@ else(AMALGAMATE_SOURCES) set_property(TARGET ${PROJECT_NAME} PROPERTY VERSION ${MINIZ_VERSION}) set_property(TARGET ${PROJECT_NAME} PROPERTY SOVERSION ${MINIZ_API_VERSION}) - + target_include_directories(${PROJECT_NAME} PUBLIC $ $ $ ) - + file(GLOB INSTALL_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/*.h) list(APPEND INSTALL_HEADERS ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_export.h) endif(AMALGAMATE_SOURCES) if(NOT BUILD_HEADER_ONLY) - target_compile_definitions(${PROJECT_NAME} + target_compile_definitions(${PROJECT_NAME} PRIVATE $<$:_GNU_SOURCE>) # pkg-config file @@ -178,6 +179,10 @@ if(NOT BUILD_HEADER_ONLY) endif() endif() +if(BUILD_NO_STDIO) + target_compile_definitions(${PROJECT_NAME} PRIVATE MINIZ_NO_STDIO) +endif() + set_property(TARGET ${PROJECT_NAME} PROPERTY INTERFACE_${PROJECT_NAME}_MAJOR_VERSION ${MINIZ_API_VERSION}) set_property(TARGET ${PROJECT_NAME} APPEND PROPERTY @@ -242,8 +247,10 @@ if(BUILD_EXAMPLES) add_executable(example1 ${EXAMPLE1_SRC_LIST}) target_link_libraries(example1 miniz) - add_executable(example2 ${EXAMPLE2_SRC_LIST}) - target_link_libraries(example2 miniz) + if(NOT BUILD_NO_STDIO) + add_executable(example2 ${EXAMPLE2_SRC_LIST}) + target_link_libraries(example2 miniz) + endif() add_executable(example3 ${EXAMPLE3_SRC_LIST}) target_link_libraries(example3 miniz) add_executable(example4 ${EXAMPLE4_SRC_LIST}) @@ -298,17 +305,18 @@ if(BUILD_FUZZERS) endif() if(BUILD_TESTS) - set(CMAKE_CXX_STANDARD 20) - set(CMAKE_CXX_STANDARD_REQUIRED YES) - - add_executable(catch_tests tests/main.cpp - tests/catch_amalgamated.cpp) - target_link_libraries(catch_tests miniz) - - enable_testing() - - add_test(NAME catch_tests - COMMAND $) + set(CMAKE_CXX_STANDARD 20) + set(CMAKE_CXX_STANDARD_REQUIRED YES) + + add_executable(catch_tests tests/main.cpp tests/catch_amalgamated.cpp) + if(BUILD_NO_STDIO) + target_compile_definitions(catch_tests PRIVATE -DMINIZ_NO_STDIO) + endif() + target_link_libraries(catch_tests miniz) + + enable_testing() + + add_test(NAME catch_tests COMMAND $) endif() set(INCLUDE_INSTALL_DIR "include") diff --git a/tests/main.cpp b/tests/main.cpp index 006f44f..85a1e13 100644 --- a/tests/main.cpp +++ b/tests/main.cpp @@ -5,8 +5,11 @@ #ifdef _WIN32 #define unlink _unlink +#else +#include #endif +#ifndef MINIZ_NO_STDIO bool create_test_zip() { unlink("test.zip"); @@ -79,6 +82,7 @@ TEST_CASE("Zip writer tests") } } } +#endif TEST_CASE("Tinfl / tdefl tests") { @@ -124,4 +128,4 @@ TEST_CASE("Tinfl / tdefl tests") REQUIRE(decomp_len == uncomp_len); REQUIRE(memcmp(decomp_buf, p, uncomp_len) == 0); } -} \ No newline at end of file +}