From 9a6f9f0c0fbc03648aea6697455d74fc00b50091 Mon Sep 17 00:00:00 2001 From: Holden Date: Mon, 19 Aug 2024 22:36:50 -0400 Subject: [PATCH] CMake: Fetch PX4-GPSDrivers --- .gitmodules | 2 +- src/GPS/Drivers => libs/PX4-GPSDrivers | 0 src/GPS/CMakeLists.txt | 134 ++++++++++++++----------- 3 files changed, 78 insertions(+), 58 deletions(-) rename src/GPS/Drivers => libs/PX4-GPSDrivers (100%) diff --git a/.gitmodules b/.gitmodules index acfcf3886462..e4ebac227f3c 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,5 +1,5 @@ [submodule "src/GPS/Drivers"] - path = src/GPS/Drivers + path = libs/PX4-GPSDrivers url = https://github.com/PX4/GpsDrivers.git [submodule "libs/mavlink/include/mavlink/v2.0"] path = libs/mavlink/include/mavlink/v2.0 diff --git a/src/GPS/Drivers b/libs/PX4-GPSDrivers similarity index 100% rename from src/GPS/Drivers rename to libs/PX4-GPSDrivers diff --git a/src/GPS/CMakeLists.txt b/src/GPS/CMakeLists.txt index 8d1ed0ae961b..eef62e187ec8 100644 --- a/src/GPS/CMakeLists.txt +++ b/src/GPS/CMakeLists.txt @@ -2,61 +2,81 @@ find_package(Qt6 REQUIRED COMPONENTS Core) qt_add_library(GPS STATIC) -if(NOT QGC_NO_SERIAL_LINK) - # include(FetchContent) - # FetchContent_Declare(gps_drivers - # GIT_REPOSITORY https://github.com/PX4/PX4-GPSDrivers.git - # GIT_TAG main - # GIT_SHALLOW TRUE - # ) - # FetchContent_GetProperties(gps_drivers) - # if(NOT gps_drivers_POPULATED) - # FetchContent_Populate(gps_drivers) - # add_subdirectory(${gps_drivers_SOURCE_DIR} ${gps_drivers_BINARY_DIR} EXCLUDE_FROM_ALL) - # endif() - - target_sources(GPS - PRIVATE - definitions.h - Drivers/src/ashtech.cpp - Drivers/src/ashtech.h - Drivers/src/gps_helper.cpp - Drivers/src/gps_helper.h - Drivers/src/mtk.cpp - Drivers/src/mtk.h - Drivers/src/rtcm.cpp - Drivers/src/rtcm.h - Drivers/src/sbf.cpp - Drivers/src/sbf.h - Drivers/src/ubx.cpp - Drivers/src/ubx.h - GPSManager.cc - GPSManager.h - GPSPositionMessage.h - GPSProvider.cc - GPSProvider.h - RTCMMavlink.cc - RTCMMavlink.h - satellite_info.h - sensor_gnss_relative.h - sensor_gps.h - ) - - target_link_libraries(GPS - PRIVATE - Settings - Utilities - Vehicle - PUBLIC - Qt6::Core - MAVLink - QGC - ) - - target_include_directories(GPS - PRIVATE - Drivers/src - INTERFACE - ${CMAKE_CURRENT_SOURCE_DIR} - ) +if(QGC_NO_SERIAL_LINK) + return() endif() + +include(FetchContent) +FetchContent_Declare(PX4-GPSDrivers + GIT_REPOSITORY https://github.com/PX4/PX4-GPSDrivers.git + GIT_TAG main + GIT_SHALLOW TRUE + SOURCE_SUBDIR src +) +FetchContent_MakeAvailable(PX4-GPSDrivers) + +qt_add_library(GPSDrivers STATIC + definitions.h + ${px4-gpsdrivers_SOURCE_DIR}/src/ashtech.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/ashtech.h + ${px4-gpsdrivers_SOURCE_DIR}/src/base_station.h + ${px4-gpsdrivers_SOURCE_DIR}/src/crc.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/crc.h + ${px4-gpsdrivers_SOURCE_DIR}/src/emlid_reach.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/emlid_reach.h + ${px4-gpsdrivers_SOURCE_DIR}/src/femtomes.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/femtomes.h + ${px4-gpsdrivers_SOURCE_DIR}/src/gps_helper.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/gps_helper.h + ${px4-gpsdrivers_SOURCE_DIR}/src/mtk.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/mtk.h + ${px4-gpsdrivers_SOURCE_DIR}/src/nmea.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/nmea.h + ${px4-gpsdrivers_SOURCE_DIR}/src/rtcm.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/rtcm.h + ${px4-gpsdrivers_SOURCE_DIR}/src/sbf.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/sbf.h + ${px4-gpsdrivers_SOURCE_DIR}/src/ubx.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/ubx.h + ${px4-gpsdrivers_SOURCE_DIR}/src/unicore.cpp + ${px4-gpsdrivers_SOURCE_DIR}/src/unicore.h +) + +target_link_libraries(GPSDrivers + PUBLIC + Qt6::Core + Utilities +) + +target_include_directories(GPSDrivers PUBLIC ${px4-gpsdrivers_SOURCE_DIR}) + +target_compile_definitions(GPSDrivers PUBLIC GPS_DEFINITIONS_HEADER=<${CMAKE_CURRENT_SOURCE_DIR}/definitions.h>) + +target_sources(GPS + PRIVATE + GPSManager.cc + GPSManager.h + GPSPositionMessage.h + GPSProvider.cc + GPSProvider.h + RTCMMavlink.cc + RTCMMavlink.h + satellite_info.h + sensor_gnss_relative.h + sensor_gps.h +) + +target_link_libraries(GPS + PRIVATE + Comms + GPSDrivers + Settings + Utilities + Vehicle + PUBLIC + Qt6::Core + MAVLink + QGC +) + +target_include_directories(GPS PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})