Merge pull request #23 from bondagit/yocto-integration
make buildsystem yocto friendly
This commit is contained in:
commit
3fa3be6aaa
4
build.sh
4
build.sh
@ -7,6 +7,8 @@
|
|||||||
export CC=/usr/bin/clang
|
export CC=/usr/bin/clang
|
||||||
export CXX=/usr/bin/clang++
|
export CXX=/usr/bin/clang++
|
||||||
|
|
||||||
|
TOPDIR=$(pwd)
|
||||||
|
|
||||||
cd 3rdparty
|
cd 3rdparty
|
||||||
if [ ! -d ravenna-alsa-lkm.git ]; then
|
if [ ! -d ravenna-alsa-lkm.git ]; then
|
||||||
git clone https://bitbucket.org/MergingTechnologies/ravenna-alsa-lkm.git
|
git clone https://bitbucket.org/MergingTechnologies/ravenna-alsa-lkm.git
|
||||||
@ -44,7 +46,7 @@ cd ..
|
|||||||
|
|
||||||
cd daemon
|
cd daemon
|
||||||
echo "Building aes67-daemon ..."
|
echo "Building aes67-daemon ..."
|
||||||
cmake -DWITH_AVAHI=ON .
|
cmake -DCPP_HTTPLIB_DIR="$TOPDIR"/3rdparty/cpp-httplib -DRAVENNA_ALSA_LKM_DIR="$TOPDIR"/3rdparty/ravenna-alsa-lkm -DENABLE_TESTS=ON -DWITH_AVAHI=ON .
|
||||||
make
|
make
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
|
@ -1,20 +1,43 @@
|
|||||||
cmake_minimum_required(VERSION 3.7.0)
|
cmake_minimum_required(VERSION 3.7.0)
|
||||||
|
|
||||||
project(aes67-daemon CXX)
|
project(aes67-daemon CXX)
|
||||||
enable_testing()
|
|
||||||
|
option(ENABLE_TESTS "Enable tests. Not recommended when cross-compiling." OFF)
|
||||||
|
if( ENABLE_TESTS )
|
||||||
|
enable_testing()
|
||||||
|
endif()
|
||||||
|
|
||||||
option(WITH_AVAHI "Include mDNS support via Avahi" OFF)
|
option(WITH_AVAHI "Include mDNS support via Avahi" OFF)
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
set(CMAKE_CXX_FLAGS "-g -DBOOST_LOG_DYN_LINK -DBOOST_LOG_USE_NATIVE_SYSLOG -Wall")
|
|
||||||
set(RAVENNA_ALSA_LKM "../3rdparty/ravenna-alsa-lkm/")
|
# ravena lkm _should_ be provided by the CLI. Nonetheless, we should be able
|
||||||
set(CPP_HTTPLIB " ../3rdparty/cpp-httplib/")
|
# to find it in system dirs too...
|
||||||
|
if ( NOT RAVENNNA_ALSA_LKM_DIR )
|
||||||
|
find_path(RAVENNA_ALSA_LKM_DIR "common/MergingRAVENNACommon.h" REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# use sysroot cpp-http lib unless one was explicitly provided in cmdline
|
||||||
|
if ( NOT CPP_HTTPLIB_DIR )
|
||||||
|
find_path( CPP_HTTPLIB_DIR "httplib.h" REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
find_library(AVAHI_LIBRARY-COMMON NAMES avahi-common)
|
find_library(AVAHI_LIBRARY-COMMON NAMES avahi-common)
|
||||||
find_library(AVAHI_LIBRARY-CLIENT NAMES avahi-client)
|
find_library(AVAHI_LIBRARY-CLIENT NAMES avahi-client)
|
||||||
find_path(AVAHI_INCLUDE_DIR avahi-client/publish.h)
|
find_path(AVAHI_INCLUDE_DIR avahi-client/publish.h)
|
||||||
set(AVAHI_LIBRARIES ${AVAHI_LIBRARY-COMMON} ${AVAHI_LIBRARY-CLIENT})
|
set(AVAHI_LIBRARIES ${AVAHI_LIBRARY-COMMON} ${AVAHI_LIBRARY-CLIENT})
|
||||||
set(AVAHI_INCLUDE_DIRS ${AVAHI_INCLUDE_DIR})
|
set(AVAHI_INCLUDE_DIRS ${AVAHI_INCLUDE_DIR})
|
||||||
|
|
||||||
find_package(Boost COMPONENTS system thread log program_options REQUIRED)
|
find_package(Boost COMPONENTS system thread log program_options REQUIRED)
|
||||||
include_directories(aes67-daemon ${RAVENNA_ALSA_LKM}/common ${RAVENNA_ALSA_LKM}/driver ${CPP_HTTPLIB} ${Boost_INCLUDE_DIR})
|
include_directories(aes67-daemon ${RAVENNA_ALSA_LKM_DIR}/common ${RAVENNA_ALSA_LKM_DIR}/driver ${CPP_HTTPLIB_DIR} ${Boost_INCLUDE_DIR})
|
||||||
|
add_definitions( -DBOOST_LOG_DYN_LINK -DBOOST_LOG_USE_NATIVE_SYSLOG )
|
||||||
|
add_compile_options( -Wall )
|
||||||
add_executable(aes67-daemon error_code.cpp json.cpp main.cpp driver_handler.cpp driver_manager.cpp session_manager.cpp http_server.cpp config.cpp interface.cpp log.cpp sap.cpp browser.cpp rtsp_client.cpp mdns_client.cpp mdns_server.cpp rtsp_server.cpp utils.cpp)
|
add_executable(aes67-daemon error_code.cpp json.cpp main.cpp driver_handler.cpp driver_manager.cpp session_manager.cpp http_server.cpp config.cpp interface.cpp log.cpp sap.cpp browser.cpp rtsp_client.cpp mdns_client.cpp mdns_server.cpp rtsp_server.cpp utils.cpp)
|
||||||
add_subdirectory(tests)
|
|
||||||
|
if( ENABLE_TESTS )
|
||||||
|
add_subdirectory(tests)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
target_link_libraries(aes67-daemon ${Boost_LIBRARIES})
|
target_link_libraries(aes67-daemon ${Boost_LIBRARIES})
|
||||||
if(WITH_AVAHI)
|
if(WITH_AVAHI)
|
||||||
MESSAGE(STATUS "WITH_AVAHI")
|
MESSAGE(STATUS "WITH_AVAHI")
|
||||||
|
@ -1,10 +1,23 @@
|
|||||||
cmake_minimum_required(VERSION 3.7.0)
|
cmake_minimum_required(VERSION 3.7.0)
|
||||||
project(daemon-test CXX)
|
project(daemon-test CXX)
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
set(CPP_HTTPLIB " ../3rdparty/cpp-httplib/")
|
|
||||||
set(CMAKE_CXX_FLAGS "-g -O3 -DBOOST_LOG_DYN_LINK -DBOOST_LOG_USE_NATIVE_SYSLOG -Wall")
|
# use sysroot cpp-http lib unless one was explicitly provided in cmdline
|
||||||
|
if ( NOT CPP_HTTPLIB_DIR )
|
||||||
|
find_path( CPP_HTTPLIB_DIR "httplib.h" REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# ravena lkm _should_ be provided by the CLI. Nonetheless, we should be able
|
||||||
|
# to find it in system dirs too...
|
||||||
|
if ( NOT RAVENNNA_ALSA_LKM_DIR )
|
||||||
|
find_path(RAVENNA_ALSA_LKM_DIR "common/MergingRAVENNACommon.h" REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_definitions( -DBOOST_LOG_DYN_LINK -DBOOST_LOG_USE_NATIVE_SYSLOG )
|
||||||
|
add_compile_options( -Wall )
|
||||||
|
|
||||||
find_package(Boost COMPONENTS unit_test_framework filesystem system thread REQUIRED)
|
find_package(Boost COMPONENTS unit_test_framework filesystem system thread REQUIRED)
|
||||||
include_directories(aes67-daemon ${CPP_HTTPLIB} ${Boost_INCLUDE_DIR})
|
include_directories(aes67-daemon ${CPP_HTTPLIB_DIR} ${RAVENNA_ALSA_LKM_DIR}/common ${RAVENNA_ALSA_LKM_DIR}/driver ${Boost_INCLUDE_DIR})
|
||||||
add_executable(daemon-test daemon_test.cpp)
|
add_executable(daemon-test daemon_test.cpp)
|
||||||
target_link_libraries(daemon-test ${Boost_LIBRARIES})
|
target_link_libraries(daemon-test ${Boost_LIBRARIES})
|
||||||
add_test(daemon-test daemon-test)
|
add_test(daemon-test daemon-test)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user