diff options
author | Scott Murray <scott.murray@konsulko.com> | 2019-08-30 11:40:23 -0400 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2019-09-05 00:18:27 +0000 |
commit | da9d177514fe438edd8262226cdc770df6c9eb82 (patch) | |
tree | e33d2af8d2e129b372caf34afac37366b641553a /CMakeLists.txt | |
parent | dd61aa309b3a082488c9d3c383c1601fd3efbc2a (diff) |
Initial check in
Initial check in of contents of the original repository:
git://github.com/AGLExport/agl-service-navigation
as of commit 1f1ffc92fcc882aa5e885badbc91a3384f5d77b1.
Bug-AGL: SPEC-2787
Signed-off-by: Scott Murray <scott.murray@konsulko.com>
Change-Id: I02d008ee73cdfd88f1e7587ee57101187b9c4d6d
(cherry picked from commit f14ecdd52975ae365af5ed32648bf55dddacb8d9)
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r-- | CMakeLists.txt | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..9bd545b --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,64 @@ +cmake_minimum_required(VERSION 2.8.11) + +INCLUDE(FindPkgConfig) + +set(PROJECT_NAME "agl-service-navigation") +set(PROJECT_PRETTY_NAME "AFM binding for navigation service") +set(PROJECT_DESCRIPTION "Binding for AGL Navigation API") +set(PROJECT_INCLUDEDIR ${CMAKE_INSTALL_PREFIX}/include) +set(PROJECT_LIBDIR ${CMAKE_INSTALL_PREFIX}/lib) +set(PROJECT_API_VERSION 0.1.0) +set(PROJECT_URL "https://wiki.automotivelinux.org/eg-navi") + +# Set a default build type if none was specified +if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) + message(STATUS "Setting build type to 'Release' as none was specified.") + set(CMAKE_BUILD_TYPE Release CACHE STRING "Choose the type of build." FORCE) +endif() + +project(navi_binder) + +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -fPIC ") + +set(CMAKE_INCLUDE_CURRENT_DIR ON) + +pkg_check_modules(DBUSCXX REQUIRED dbus-c++-1) +pkg_check_modules(JSON REQUIRED json-c) +pkg_check_modules(AFBWSC REQUIRED libafbwsc) + +include_directories( ${PROJECT_SOURCE_DIR}/libnavi/include ${PROJECT_SOURCE_DIR}/include ${DBUSCXX_INCLUDE_DIRS} ${JSON_INCLUDE_DIRS} ${AFBWSC_INCLUDE_DIRS} ) + +add_library( naviapi-agl SHARED libnavi/src/navicore.cpp libnavi/src/navicorelistener.cpp libnavi/src/BinderClient.cpp libnavi/src/JsonRequestGenerator.cpp libnavi/src/JsonResponseAnalyzer.cpp libnavi/src/RequestManage.cpp ) +target_link_libraries( naviapi-agl ${JSON_LIBRARIES} ${AFBWSC_LIBRARIES} ) +set_target_properties(naviapi-agl PROPERTIES VERSION 0.1.0 SOVERSION 0) + +install(TARGETS naviapi-agl LIBRARY DESTINATION ${PROJECT_LIBDIR}) +install(FILES ${PROJECT_SOURCE_DIR}/libnavi/include/libnavicore.hpp DESTINATION ${PROJECT_INCLUDEDIR}) + +add_library( NaviAPIService SHARED src/api.cpp src/analyze_request.cpp src/binder_reply.cpp src/genivi_request.cpp ) + +target_link_libraries( NaviAPIService ${DBUSCXX_LIBRARIES} ${JSON_LIBRARIES} ${AFBWSC_LIBRARIES} ) + +########################################################################## +# AGL binding +configure_file(config.xml.in config.xml) +set(BINARY_NAME "naviapi.wgt") + +add_custom_command( + OUTPUT ${BINARY_NAME} + DEPENDS NaviAPIService + COMMAND rm -rf package + COMMAND mkdir -p package/root + COMMAND mkdir -p package/root/lib + COMMAND mv config.xml package/root/ + COMMAND cp ${CMAKE_CURRENT_SOURCE_DIR}/navigation.png package/root/icon.png + COMMAND mv libNaviAPIService.so package/root/lib + COMMAND wgtpkg-pack -f -o package/${BINARY_NAME} package/root +) +add_custom_target(widget ALL DEPENDS ${BINARY_NAME}) + +#generate configure file +configure_file(libnaviapi-agl.pc.in libnaviapi-agl.pc @ONLY) +INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/libnaviapi-agl.pc + DESTINATION + ${CMAKE_INSTALL_PREFIX}/lib/pkgconfig) |