|
@@ -1,7 +1,7 @@
|
|
cmake_minimum_required(VERSION 3.7)
|
|
cmake_minimum_required(VERSION 3.7)
|
|
project(libdatachannel
|
|
project(libdatachannel
|
|
DESCRIPTION "WebRTC DataChannels Library"
|
|
DESCRIPTION "WebRTC DataChannels Library"
|
|
- VERSION 0.4.9
|
|
|
|
|
|
+ VERSION 0.5.0
|
|
LANGUAGES CXX)
|
|
LANGUAGES CXX)
|
|
|
|
|
|
option(USE_GNUTLS "Use GnuTLS instead of OpenSSL" OFF)
|
|
option(USE_GNUTLS "Use GnuTLS instead of OpenSSL" OFF)
|
|
@@ -73,7 +73,8 @@ set(TESTS_SOURCES
|
|
${CMAKE_CURRENT_SOURCE_DIR}/test/capi.cpp
|
|
${CMAKE_CURRENT_SOURCE_DIR}/test/capi.cpp
|
|
)
|
|
)
|
|
|
|
|
|
-set(THREADS_PREFER_PTHREAD_FLAG ON)
|
|
|
|
|
|
+set(CMAKE_THREAD_PREFER_PTHREAD TRUE)
|
|
|
|
+set(THREADS_PREFER_PTHREAD_FLAG TRUE)
|
|
find_package(Threads REQUIRED)
|
|
find_package(Threads REQUIRED)
|
|
|
|
|
|
add_subdirectory(deps/usrsctp EXCLUDE_FROM_ALL)
|
|
add_subdirectory(deps/usrsctp EXCLUDE_FROM_ALL)
|
|
@@ -114,21 +115,22 @@ set_target_properties(datachannel-static PROPERTIES
|
|
CXX_STANDARD 17)
|
|
CXX_STANDARD 17)
|
|
|
|
|
|
target_include_directories(datachannel PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
target_include_directories(datachannel PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
|
|
+target_include_directories(datachannel PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/deps/plog/include)
|
|
target_include_directories(datachannel PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/rtc)
|
|
target_include_directories(datachannel PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/rtc)
|
|
target_include_directories(datachannel PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src)
|
|
target_include_directories(datachannel PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src)
|
|
-target_include_directories(datachannel PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/deps/plog/include)
|
|
|
|
|
|
+target_link_libraries(datachannel PUBLIC Threads::Threads)
|
|
|
|
+target_link_libraries(datachannel PRIVATE Usrsctp::UsrsctpStatic)
|
|
|
|
|
|
target_include_directories(datachannel-static PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
target_include_directories(datachannel-static PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
|
|
+target_include_directories(datachannel-static PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/deps/plog/include)
|
|
target_include_directories(datachannel-static PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/rtc)
|
|
target_include_directories(datachannel-static PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/rtc)
|
|
target_include_directories(datachannel-static PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src)
|
|
target_include_directories(datachannel-static PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src)
|
|
-target_include_directories(datachannel-static PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/deps/plog/include)
|
|
|
|
-
|
|
|
|
-target_link_libraries(datachannel Threads::Threads Usrsctp::UsrsctpStatic)
|
|
|
|
-target_link_libraries(datachannel-static Threads::Threads Usrsctp::UsrsctpStatic)
|
|
|
|
|
|
+target_link_libraries(datachannel-static PUBLIC Threads::Threads)
|
|
|
|
+target_link_libraries(datachannel-static PRIVATE Usrsctp::UsrsctpStatic)
|
|
|
|
|
|
if(WIN32)
|
|
if(WIN32)
|
|
- target_link_libraries(datachannel "wsock32" "ws2_32") # winsock2
|
|
|
|
- target_link_libraries(datachannel-static "wsock32" "ws2_32") # winsock2
|
|
|
|
|
|
+ target_link_libraries(datachannel PRIVATE wsock32 ws2_32) # winsock2
|
|
|
|
+ target_link_libraries(datachannel-static PRIVATE wsock32 ws2_32) # winsock2
|
|
endif()
|
|
endif()
|
|
|
|
|
|
if (USE_GNUTLS)
|
|
if (USE_GNUTLS)
|
|
@@ -142,29 +144,29 @@ if (USE_GNUTLS)
|
|
IMPORTED_LOCATION "${GNUTLS_LIBRARIES}")
|
|
IMPORTED_LOCATION "${GNUTLS_LIBRARIES}")
|
|
endif()
|
|
endif()
|
|
target_compile_definitions(datachannel PRIVATE USE_GNUTLS=1)
|
|
target_compile_definitions(datachannel PRIVATE USE_GNUTLS=1)
|
|
- target_link_libraries(datachannel GnuTLS::GnuTLS)
|
|
|
|
|
|
+ target_link_libraries(datachannel PRIVATE GnuTLS::GnuTLS)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_GNUTLS=1)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_GNUTLS=1)
|
|
- target_link_libraries(datachannel-static GnuTLS::GnuTLS)
|
|
|
|
|
|
+ target_link_libraries(datachannel-static PRIVATE GnuTLS::GnuTLS)
|
|
else()
|
|
else()
|
|
find_package(OpenSSL REQUIRED)
|
|
find_package(OpenSSL REQUIRED)
|
|
target_compile_definitions(datachannel PRIVATE USE_GNUTLS=0)
|
|
target_compile_definitions(datachannel PRIVATE USE_GNUTLS=0)
|
|
- target_link_libraries(datachannel OpenSSL::SSL)
|
|
|
|
|
|
+ target_link_libraries(datachannel PRIVATE OpenSSL::SSL)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_GNUTLS=0)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_GNUTLS=0)
|
|
- target_link_libraries(datachannel-static OpenSSL::SSL)
|
|
|
|
|
|
+ target_link_libraries(datachannel-static PRIVATE OpenSSL::SSL)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
if (USE_JUICE)
|
|
if (USE_JUICE)
|
|
add_subdirectory(deps/libjuice EXCLUDE_FROM_ALL)
|
|
add_subdirectory(deps/libjuice EXCLUDE_FROM_ALL)
|
|
target_compile_definitions(datachannel PRIVATE USE_JUICE=1)
|
|
target_compile_definitions(datachannel PRIVATE USE_JUICE=1)
|
|
- target_link_libraries(datachannel LibJuice::LibJuiceStatic)
|
|
|
|
|
|
+ target_link_libraries(datachannel PRIVATE LibJuice::LibJuiceStatic)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_JUICE=1)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_JUICE=1)
|
|
- target_link_libraries(datachannel-static LibJuice::LibJuiceStatic)
|
|
|
|
|
|
+ target_link_libraries(datachannel-static PRIVATE LibJuice::LibJuiceStatic)
|
|
else()
|
|
else()
|
|
find_package(LibNice REQUIRED)
|
|
find_package(LibNice REQUIRED)
|
|
target_compile_definitions(datachannel PRIVATE USE_JUICE=0)
|
|
target_compile_definitions(datachannel PRIVATE USE_JUICE=0)
|
|
- target_link_libraries(datachannel LibNice::LibNice)
|
|
|
|
|
|
+ target_link_libraries(datachannel PRIVATE LibNice::LibNice)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_JUICE=0)
|
|
target_compile_definitions(datachannel-static PRIVATE USE_JUICE=0)
|
|
- target_link_libraries(datachannel-static LibNice::LibNice)
|
|
|
|
|
|
+ target_link_libraries(datachannel-static PRIVATE LibNice::LibNice)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
add_library(LibDataChannel::LibDataChannel ALIAS datachannel)
|
|
add_library(LibDataChannel::LibDataChannel ALIAS datachannel)
|