[cppcoro] Simplify CMakeLists.txt to ease future maintenance. Fix VS 2019 builds.

This commit is contained in:
Robert Schumacher 2020-04-24 03:04:26 -07:00
parent fe0202d7f3
commit b009c2e5b0
3 changed files with 33 additions and 169 deletions

View File

@ -1,7 +1,8 @@
cmake_minimum_required(VERSION 3.8) cmake_minimum_required(VERSION 3.8)
project(cppcoro VERSION 2020.2 LANGUAGES CXX) project(cppcoro VERSION 2020.2 LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 17)
add_library(cppcoro add_library(cppcoro
lib/async_mutex.cpp lib/async_mutex.cpp
lib/lightweight_manual_reset_event.cpp lib/lightweight_manual_reset_event.cpp
@ -27,14 +28,8 @@ add_library(cppcoro
lib/ipv6_endpoint.cpp lib/ipv6_endpoint.cpp
) )
set_target_properties(cppcoro
PROPERTIES
CXX_STANDARD 17 # expect C++ Coroutines TS <experimental/coroutine>
)
if(APPLE) if(APPLE)
message(STATUS "using sysroot: ${CMAKE_OSX_SYSROOT}") message(STATUS "using sysroot: ${CMAKE_OSX_SYSROOT}")
elseif(WIN32) elseif(WIN32)
message(STATUS "using platform: ${CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION}") message(STATUS "using platform: ${CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION}")
# for now, build in single target # for now, build in single target
@ -61,103 +56,17 @@ elseif(WIN32)
lib/socket_recv_operation.cpp lib/socket_recv_operation.cpp
lib/io_service.cpp lib/io_service.cpp
) )
list(APPEND detail_headers elseif(CMAKE_SYSTEM_NAME MATCHES "Linux")
include/cppcoro/detail/win32.hpp
include/cppcoro/detail/win32_overlapped_operation.hpp
)
list(APPEND net_headers
include/cppcoro/net/socket.hpp
include/cppcoro/net/socket_accept_operation.hpp
include/cppcoro/net/socket_connect_operation.hpp
include/cppcoro/net/socket_disconnect_operation.hpp
include/cppcoro/net/socket_recv_operation.hpp
include/cppcoro/net/socket_recv_from_operation.hpp
include/cppcoro/net/socket_send_operation.hpp
include/cppcoro/net/socket_send_to_operation.hpp
)
elseif(CMAKE_SYSTEM_NAME MATCHES Linux)
message(STATUS "using system: ${CMAKE_HOST_SYSTEM_VERSION}") message(STATUS "using system: ${CMAKE_HOST_SYSTEM_VERSION}")
endif() endif()
list(APPEND headers
include/cppcoro/awaitable_traits.hpp
include/cppcoro/is_awaitable.hpp
include/cppcoro/async_auto_reset_event.hpp
include/cppcoro/async_manual_reset_event.hpp
include/cppcoro/async_generator.hpp
include/cppcoro/async_mutex.hpp
include/cppcoro/async_latch.hpp
include/cppcoro/async_scope.hpp
include/cppcoro/broken_promise.hpp
include/cppcoro/cancellation_registration.hpp
include/cppcoro/cancellation_source.hpp
include/cppcoro/cancellation_token.hpp
include/cppcoro/task.hpp
include/cppcoro/sequence_barrier.hpp
include/cppcoro/sequence_traits.hpp
include/cppcoro/single_producer_sequencer.hpp
include/cppcoro/multi_producer_sequencer.hpp
include/cppcoro/shared_task.hpp
include/cppcoro/single_consumer_event.hpp
include/cppcoro/single_consumer_async_auto_reset_event.hpp
include/cppcoro/sync_wait.hpp
include/cppcoro/task.hpp
include/cppcoro/io_service.hpp
include/cppcoro/config.hpp
include/cppcoro/on_scope_exit.hpp
include/cppcoro/file_share_mode.hpp
include/cppcoro/file_open_mode.hpp
include/cppcoro/file_buffering_mode.hpp
include/cppcoro/file.hpp
include/cppcoro/fmap.hpp
include/cppcoro/when_all.hpp
include/cppcoro/when_all_ready.hpp
include/cppcoro/resume_on.hpp
include/cppcoro/schedule_on.hpp
include/cppcoro/generator.hpp
include/cppcoro/readable_file.hpp
include/cppcoro/recursive_generator.hpp
include/cppcoro/writable_file.hpp
include/cppcoro/read_only_file.hpp
include/cppcoro/write_only_file.hpp
include/cppcoro/read_write_file.hpp
include/cppcoro/file_read_operation.hpp
include/cppcoro/file_write_operation.hpp
include/cppcoro/static_thread_pool.hpp
)
list(APPEND detail_headers
include/cppcoro/detail/void_value.hpp
include/cppcoro/detail/when_all_ready_awaitable.hpp
include/cppcoro/detail/when_all_counter.hpp
include/cppcoro/detail/when_all_task.hpp
include/cppcoro/detail/get_awaiter.hpp
include/cppcoro/detail/is_awaiter.hpp
include/cppcoro/detail/any.hpp
include/cppcoro/detail/sync_wait_task.hpp
include/cppcoro/detail/unwrap_reference.hpp
include/cppcoro/detail/lightweight_manual_reset_event.hpp
)
list(APPEND net_headers
include/cppcoro/net/ip_address.hpp
include/cppcoro/net/ip_endpoint.hpp
include/cppcoro/net/ipv4_address.hpp
include/cppcoro/net/ipv4_endpoint.hpp
include/cppcoro/net/ipv6_address.hpp
include/cppcoro/net/ipv6_endpoint.hpp
include/cppcoro/net/socket.hpp
)
target_include_directories(cppcoro target_include_directories(cppcoro
PUBLIC PUBLIC
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include> $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
$<INSTALL_INTERFACE:${CMAKE_INSTALL_PREFIX}/include> $<INSTALL_INTERFACE:include>
) )
if(${CMAKE_CXX_COMPILER_ID} MATCHES Clang) if("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang")
if(WIN32) if(WIN32)
message(FATAL_ERROR "<experimental/resumable> doesn't support clang-cl compiler") message(FATAL_ERROR "<experimental/resumable> doesn't support clang-cl compiler")
else() else()
@ -165,24 +74,20 @@ if(${CMAKE_CXX_COMPILER_ID} MATCHES Clang)
PUBLIC PUBLIC
-std=c++1z -fcoroutines-ts -std=c++1z -fcoroutines-ts
-stdlib=libc++ -stdlib=libc++
PRIVATE
-fPIC
) )
target_link_libraries(cppcoro target_link_libraries(cppcoro
PUBLIC PUBLIC
c++ pthread c++ pthread
PRIVATE
-Wall
) )
endif() endif()
elseif(MSVC) elseif(MSVC)
target_compile_options(cppcoro target_compile_options(cppcoro
PUBLIC PUBLIC
/std:c++latest /await /await
/W4
PRIVATE PRIVATE
"/analyze:max_paths 512" "/analyze:max_paths 512"
-D_SILENCE_EXPERIMENTAL_FILESYSTEM_DEPRECATION_WARNING=1
) )
if(CMAKE_GENERATOR_PLATFORM STREQUAL x64) if(CMAKE_GENERATOR_PLATFORM STREQUAL x64)
target_compile_options(cppcoro target_compile_options(cppcoro
@ -194,11 +99,6 @@ elseif(MSVC)
endif() endif()
if(WIN32) if(WIN32)
set_target_properties(cppcoro
PROPERTIES
WINDOWS_EXPORT_ALL_SYMBOLS True
)
target_link_libraries(cppcoro target_link_libraries(cppcoro
PUBLIC PUBLIC
kernel32 synchronization ws2_32 mswsock kernel32 synchronization ws2_32 mswsock
@ -213,24 +113,19 @@ elseif(CMAKE_SYSTEM_NAME MATCHES Linux)
) )
endif() endif()
install(FILES ${headers} install(DIRECTORY include/cppcoro
DESTINATION ${CMAKE_INSTALL_PREFIX}/include/cppcoro DESTINATION include
)
install(FILES ${detail_headers}
DESTINATION ${CMAKE_INSTALL_PREFIX}/include/cppcoro/details
)
install(FILES ${net_headers}
DESTINATION ${CMAKE_INSTALL_PREFIX}/include/cppcoro/net
) )
install(TARGETS cppcoro install(TARGETS cppcoro
EXPORT ${PROJECT_NAME}-config EXPORT ${PROJECT_NAME}-config
RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin RUNTIME DESTINATION bin
LIBRARY DESTINATION ${CMAKE_INSTALL_PREFIX}/lib LIBRARY DESTINATION lib
ARCHIVE DESTINATION ${CMAKE_INSTALL_PREFIX}/lib ARCHIVE DESTINATION lib
) )
install(EXPORT ${PROJECT_NAME}-config install(EXPORT ${PROJECT_NAME}-config
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME} DESTINATION share/${PROJECT_NAME}
) )
include(CMakePackageConfigHelpers) include(CMakePackageConfigHelpers)
@ -241,7 +136,7 @@ write_basic_package_version_file(${VERSION_FILE_PATH}
) )
install(FILES ${VERSION_FILE_PATH} install(FILES ${VERSION_FILE_PATH}
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME} DESTINATION share/${PROJECT_NAME}
) )
if(NOT BUILD_TESTING) if(NOT BUILD_TESTING)
@ -278,54 +173,21 @@ add_executable(cppcoro_test
test/static_thread_pool_tests.cpp test/static_thread_pool_tests.cpp
) )
set_target_properties(cppcoro_test
PROPERTIES
CXX_STANDARD 17 # follow that of `cppcoro` target
)
target_link_libraries(cppcoro_test target_link_libraries(cppcoro_test
PRIVATE PRIVATE
cppcoro cppcoro
Threads::Threads Threads::Threads
) )
set(conan_path ${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) find_package(doctest CONFIG REQUIRED)
if(EXISTS ${conan_path}) get_target_property(DOCTEST_INCLUDE_DIR doctest::doctest
include(${conan_path}) INTERFACE_INCLUDE_DIRECTORIES
conan_basic_setup() )
message(STATUS "using conan: ${conan_path}") message(STATUS "using doctest: ${DOCTEST_INCLUDE_DIR}")
target_link_libraries(cppcoro_test
target_include_directories(cppcoro_test PRIVATE
PRIVATE doctest::doctest
${CONAN_INCLUDE_DIRS} )
)
target_compile_options(cppcoro_test
PRIVATE
${CONAN_DEFINES}
)
#
# 'doctest' is header-only library.
# we don't need these functions (and it requires CMake 3.13+)
#
# target_link_directories(cppcoro_test
# PRIVATE
# ${CONAN_LIB_DIRS}
# )
target_link_libraries(cppcoro_test
PRIVATE
${CONAN_LIBS}
)
else()
find_package(doctest CONFIG REQUIRED)
get_target_property(DOCTEST_INCLUDE_DIR doctest::doctest
INTERFACE_INCLUDE_DIRECTORIES
)
message(STATUS "using doctest: ${DOCTEST_INCLUDE_DIR}")
target_link_libraries(cppcoro_test
PRIVATE
doctest::doctest
)
endif()
if(WIN32) if(WIN32)
target_sources(cppcoro_test target_sources(cppcoro_test
@ -335,8 +197,6 @@ if(WIN32)
test/file_tests.cpp test/file_tests.cpp
test/socket_tests.cpp test/socket_tests.cpp
) )
else()
endif() endif()
add_test(NAME test_all COMMAND cppcoro_test --duration=true ) add_test(NAME test_all COMMAND cppcoro_test --duration=true )

View File

@ -1,5 +1,5 @@
Source: cppcoro Source: cppcoro
Homepage: https://github.com/lewissbaker/cppcoro Homepage: https://github.com/lewissbaker/cppcoro
Version: 2020-2-28 Version: 2020-2-28-1
Description: A library of C++ coroutine abstractions for the Coroutines TS Description: A library of C++ coroutine abstractions for the Coroutines TS
Supports: !(uwp|linux) Supports: !uwp

View File

@ -1,8 +1,10 @@
vcpkg_fail_port_install(ON_TARGET "uwp")
# for Linux, the port requires libc++ and Clang. see #10693
vcpkg_fail_port_install(ON_TARGET "uwp" "linux")
vcpkg_check_linkage(ONLY_STATIC_LIBRARY) vcpkg_check_linkage(ONLY_STATIC_LIBRARY)
if(VCPKG_TARGET_IS_LINUX)
message("Warning: cppcoro requires libc++ and Clang on Linux. See https://github.com/microsoft/vcpkg/pull/10693#issuecomment-610394650.")
endif()
vcpkg_from_github( vcpkg_from_github(
OUT_SOURCE_PATH SOURCE_PATH OUT_SOURCE_PATH SOURCE_PATH
REPO lewissbaker/cppcoro REPO lewissbaker/cppcoro
@ -23,6 +25,8 @@ vcpkg_configure_cmake(
) )
vcpkg_install_cmake() vcpkg_install_cmake()
vcpkg_fixup_cmake_targets()
file(INSTALL ${SOURCE_PATH}/LICENSE.txt file(INSTALL ${SOURCE_PATH}/LICENSE.txt
DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT}
RENAME copyright RENAME copyright