Skip to content

Commit

Permalink
feat: add lanelet2_matching
Browse files Browse the repository at this point in the history
  • Loading branch information
wu-vincent committed Nov 21, 2023
1 parent ce99dcc commit f6708f5
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 32 deletions.
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -23,4 +23,4 @@ add_subdirectory(lanelet2_validation)
#add_subdirectory(lanelet2_examples)
#add_subdirectory(lanelet2_python)
add_subdirectory(lanelet2_maps)
#add_subdirectory(lanelet2_matching)
add_subdirectory(lanelet2_matching)
2 changes: 1 addition & 1 deletion conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ class Lanelet2Conan(ConanFile):
proj_list = [
'lanelet2_core',
'lanelet2_io',
# 'lanelet2_matching',
'lanelet2_matching',
'lanelet2_projection',
'lanelet2_traffic_rules',
'lanelet2_routing',
Expand Down
78 changes: 52 additions & 26 deletions lanelet2_matching/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,63 +1,72 @@
set(MRT_PKG_VERSION 4.0.0)
#set(MRT_PKG_VERSION 4.0.0)
# Modify only if you know what you are doing!
cmake_minimum_required(VERSION 3.5.1)
project(lanelet2_matching)

###################
## Find packages ##
###################
find_package(mrt_cmake_modules REQUIRED)
include(UseMrtStdCompilerFlags)
include(GatherDeps)
#find_package(mrt_cmake_modules REQUIRED)
#include(UseMrtStdCompilerFlags)
#include(GatherDeps)

# You can add a custom.cmake in order to add special handling for this package. E.g. you can do:
# list(REMOVE_ITEM DEPENDEND_PACKAGES <package name 1> <package name 2> ...)
# To remove libs which cannot be found automatically. You can also "find_package" other, custom dependencies there.
# You can also set PROJECT_INSTALL_FILES to install files that are not installed by default.
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/custom.cmake")
include("${CMAKE_CURRENT_SOURCE_DIR}/custom.cmake")
endif()
#if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/custom.cmake")
# include("${CMAKE_CURRENT_SOURCE_DIR}/custom.cmake")
#endif()

find_package(AutoDeps REQUIRED COMPONENTS ${DEPENDEND_PACKAGES})
#find_package(AutoDeps REQUIRED COMPONENTS ${DEPENDEND_PACKAGES})

mrt_parse_package_xml()
#mrt_parse_package_xml()

########################
## Add python modules ##
########################
# This adds a python module if located under src/{PROJECT_NAME)
mrt_python_module_setup()
#mrt_python_module_setup()

mrt_glob_files(PROJECT_PYTHON_SOURCE_FILES_SRC "python_api/*.cpp")
if (PROJECT_PYTHON_SOURCE_FILES_SRC)
# Add a cpp-python api library. Make sure there are no name collisions with python modules in this project
mrt_add_python_api( ${PROJECT_NAME}
FILES ${PROJECT_PYTHON_SOURCE_FILES_SRC}
)
endif()
#mrt_glob_files(PROJECT_PYTHON_SOURCE_FILES_SRC "python_api/*.cpp")
#if (PROJECT_PYTHON_SOURCE_FILES_SRC)
# Add a cpp-python api library. Make sure there are no name collisions with python modules in this project
# mrt_add_python_api( ${PROJECT_NAME}
# FILES ${PROJECT_PYTHON_SOURCE_FILES_SRC}
# )
#endif()

############################
## Read source code files ##
############################
mrt_glob_files_recurse(PROJECT_HEADER_FILES_INC "include/*.h" "include/*.hpp" "include/*.cuh")
mrt_glob_files(PROJECT_SOURCE_FILES_INC "src/*.h" "src/*.hpp" "src/*.cuh")
mrt_glob_files(PROJECT_SOURCE_FILES_SRC "src/*.cpp" "src/*.cu")
#mrt_glob_files_recurse(PROJECT_HEADER_FILES_INC "include/*.h" "include/*.hpp" "include/*.cuh")
#mrt_glob_files(PROJECT_SOURCE_FILES_INC "src/*.h" "src/*.hpp" "src/*.cuh")
#mrt_glob_files(PROJECT_SOURCE_FILES_SRC "src/*.cpp" "src/*.cu")
file(GLOB PROJECT_SOURCE_FILES_SRC "${CMAKE_CURRENT_SOURCE_DIR}/src/*.cpp")

###########
## Build ##
###########
# Declare a cpp library
mrt_add_library(${PROJECT_NAME}
INCLUDES ${PROJECT_HEADER_FILES_INC} ${PROJECT_SOURCE_FILES_INC}
SOURCES ${PROJECT_SOURCE_FILES_SRC}
)
#mrt_add_library(${PROJECT_NAME}
# INCLUDES ${PROJECT_HEADER_FILES_INC} ${PROJECT_SOURCE_FILES_INC}
# SOURCES ${PROJECT_SOURCE_FILES_SRC}
# )
add_library(${PROJECT_NAME} SHARED ${PROJECT_SOURCE_FILES_SRC})
target_include_directories(${PROJECT_NAME} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/include")
target_link_libraries(${PROJECT_NAME} PUBLIC lanelet2_core lanelet2_io lanelet2_projection lanelet2_traffic_rules)


#############
## Install ##
#############
# Install all targets, headers by default and scripts and other files if specified (folders or files).
# This command also exports libraries and config files for dependent packages and this supersedes catkin_package.
mrt_install(PROGRAMS scripts FILES res data ${PROJECT_INSTALL_FILES})
#mrt_install(PROGRAMS scripts FILES res data ${PROJECT_INSTALL_FILES})
install(TARGETS ${PROJECT_NAME}
ARCHIVE DESTINATION ${PROJECT_INSTALL_FILES}
LIBRARY DESTINATION ${PROJECT_INSTALL_FILES}
RUNTIME DESTINATION ${PROJECT_INSTALL_FILES})

#############
## Testing ##
Expand All @@ -66,4 +75,21 @@ mrt_install(PROGRAMS scripts FILES res data ${PROJECT_INSTALL_FILES})
if (CATKIN_ENABLE_TESTING)
mrt_add_tests(test)
mrt_add_nosetests(test)
endif()
endif ()

if (LANELET2_ENABLE_TESTING)
include(GoogleTest)
find_package(GTest REQUIRED)
file(GLOB PROJECT_SOURCE_FILES_TEST "${CMAKE_CURRENT_SOURCE_DIR}/test/*.cpp")
add_executable("${PROJECT_NAME}_test" ${PROJECT_SOURCE_FILES_TEST})
target_link_libraries("${PROJECT_NAME}_test" PRIVATE GTest::gtest_main ${PROJECT_NAME})

add_custom_command(TARGET "${PROJECT_NAME}_test" POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different "$<TARGET_FILE:lanelet2_core>" "$<TARGET_FILE_DIR:${PROJECT_NAME}_test>"
COMMAND ${CMAKE_COMMAND} -E copy_if_different "$<TARGET_FILE:lanelet2_io>" "$<TARGET_FILE_DIR:${PROJECT_NAME}_test>"
COMMAND ${CMAKE_COMMAND} -E copy_if_different "$<TARGET_FILE:lanelet2_traffic_rules>" "$<TARGET_FILE_DIR:${PROJECT_NAME}_test>"
COMMAND ${CMAKE_COMMAND} -E copy_if_different "$<TARGET_FILE:lanelet2_projection>" "$<TARGET_FILE_DIR:${PROJECT_NAME}_test>")

gtest_discover_tests("${PROJECT_NAME}_test")
# add_dependencies("${PROJECT_NAME}_test" lanelet2_maps)
endif ()
4 changes: 2 additions & 2 deletions lanelet2_matching/src/LaneletMatching.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,12 +28,12 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

#include "LaneletMatching.h"
#include "lanelet2_matching/LaneletMatching.h"

#include <lanelet2_core/geometry/Lanelet.h>
#include <lanelet2_core/geometry/Polygon.h>

#include "Utilities.h"
#include "lanelet2_matching/Utilities.h"

namespace {
template <typename LaneletT, typename MatchT>
Expand Down
2 changes: 1 addition & 1 deletion lanelet2_matching/src/Utilities.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

#include "Utilities.h"
#include "lanelet2_matching/Utilities.h"

#include <lanelet2_core/geometry/Lanelet.h>
#include <lanelet2_core/geometry/Polygon.h>
Expand Down
2 changes: 1 addition & 1 deletion lanelet2_matching/test/lanelet2_matching.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@
#include <lanelet2_traffic_rules/TrafficRules.h>
#include <lanelet2_traffic_rules/TrafficRulesFactory.h>

#include "LaneletMatching.h"
#include "gtest/gtest.h"
#include "lanelet2_matching/LaneletMatching.h"

using namespace lanelet;

Expand Down

0 comments on commit f6708f5

Please sign in to comment.