211 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
			
		
		
	
	
			211 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
| cmake_minimum_required(VERSION 3.0.2)
 | |
| project(Aee1220310013)
 | |
| 
 | |
| ## Compile as C++11, supported in ROS Kinetic and newer
 | |
| # add_compile_options(-std=c++11)
 | |
| 
 | |
| ## Find catkin macros and libraries
 | |
| ## if COMPONENTS list like find_package(catkin REQUIRED COMPONENTS xyz)
 | |
| ## is used, also find other catkin packages
 | |
| find_package(catkin REQUIRED COMPONENTS
 | |
|   geometry_msgs
 | |
|   message_generation
 | |
|   rospy
 | |
|   std_msgs
 | |
|   visualization_msgs
 | |
| )
 | |
| 
 | |
| ## System dependencies are found with CMake's conventions
 | |
| # find_package(Boost REQUIRED COMPONENTS system)
 | |
| 
 | |
| 
 | |
| ## Uncomment this if the package has a setup.py. This macro ensures
 | |
| ## modules and global scripts declared therein get installed
 | |
| ## See http://ros.org/doc/api/catkin/html/user_guide/setup_dot_py.html
 | |
| # catkin_python_setup()
 | |
| 
 | |
| ################################################
 | |
| ## Declare ROS messages, services and actions ##
 | |
| ################################################
 | |
| 
 | |
| ## To declare and build messages, services or actions from within this
 | |
| ## package, follow these steps:
 | |
| ## * Let MSG_DEP_SET be the set of packages whose message types you use in
 | |
| ##   your messages/services/actions (e.g. std_msgs, actionlib_msgs, ...).
 | |
| ## * In the file package.xml:
 | |
| ##   * add a build_depend tag for "message_generation"
 | |
| ##   * add a build_depend and a exec_depend tag for each package in MSG_DEP_SET
 | |
| ##   * If MSG_DEP_SET isn't empty the following dependency has been pulled in
 | |
| ##     but can be declared for certainty nonetheless:
 | |
| ##     * add a exec_depend tag for "message_runtime"
 | |
| ## * In this file (CMakeLists.txt):
 | |
| ##   * add "message_generation" and every package in MSG_DEP_SET to
 | |
| ##     find_package(catkin REQUIRED COMPONENTS ...)
 | |
| ##   * add "message_runtime" and every package in MSG_DEP_SET to
 | |
| ##     catkin_package(CATKIN_DEPENDS ...)
 | |
| ##   * uncomment the add_*_files sections below as needed
 | |
| ##     and list every .msg/.srv/.action file to be processed
 | |
| ##   * uncomment the generate_messages entry below
 | |
| ##   * add every package in MSG_DEP_SET to generate_messages(DEPENDENCIES ...)
 | |
| 
 | |
| ## Generate messages in the 'msg' folder
 | |
| # add_message_files(
 | |
| #   FILES
 | |
| #   Message1.msg
 | |
| #   Message2.msg
 | |
| # )
 | |
| 
 | |
| ## Generate services in the 'srv' folder
 | |
| add_service_files(
 | |
|   FILES
 | |
|   ProcessID.srv
 | |
| #   Service1.srv
 | |
| #   Service2.srv
 | |
| )
 | |
| 
 | |
| ## Generate actions in the 'action' folder
 | |
| # add_action_files(
 | |
| #   FILES
 | |
| #   Action1.action
 | |
| #   Action2.action
 | |
| # )
 | |
| 
 | |
| ## Generate added messages and services with any dependencies listed here
 | |
| generate_messages(
 | |
|   DEPENDENCIES
 | |
| #   geometry_msgs#   
 | |
|   std_msgs#   visualization_msgs
 | |
| )
 | |
| 
 | |
| ################################################
 | |
| ## Declare ROS dynamic reconfigure parameters ##
 | |
| ################################################
 | |
| 
 | |
| ## To declare and build dynamic reconfigure parameters within this
 | |
| ## package, follow these steps:
 | |
| ## * In the file package.xml:
 | |
| ##   * add a build_depend and a exec_depend tag for "dynamic_reconfigure"
 | |
| ## * In this file (CMakeLists.txt):
 | |
| ##   * add "dynamic_reconfigure" to
 | |
| ##     find_package(catkin REQUIRED COMPONENTS ...)
 | |
| ##   * uncomment the "generate_dynamic_reconfigure_options" section below
 | |
| ##     and list every .cfg file to be processed
 | |
| 
 | |
| ## Generate dynamic reconfigure parameters in the 'cfg' folder
 | |
| # generate_dynamic_reconfigure_options(
 | |
| #   cfg/DynReconf1.cfg
 | |
| #   cfg/DynReconf2.cfg
 | |
| # )
 | |
| 
 | |
| ###################################
 | |
| ## catkin specific configuration ##
 | |
| ###################################
 | |
| ## The catkin_package macro generates cmake config files for your package
 | |
| ## Declare things to be passed to dependent projects
 | |
| ## INCLUDE_DIRS: uncomment this if your package contains header files
 | |
| ## LIBRARIES: libraries you create in this project that dependent projects also need
 | |
| ## CATKIN_DEPENDS: catkin_packages dependent projects also need
 | |
| ## DEPENDS: system dependencies of this project that dependent projects also need
 | |
| catkin_package(
 | |
| #  INCLUDE_DIRS include
 | |
| #  LIBRARIES Aee1220310013
 | |
| #  CATKIN_DEPENDS geometry_msgs message_generation rospy std_msgs visualization_msgs
 | |
| #  DEPENDS system_lib
 | |
| )
 | |
| 
 | |
| ###########
 | |
| ## Build ##
 | |
| ###########
 | |
| 
 | |
| ## Specify additional locations of header files
 | |
| ## Your package locations should be listed before other locations
 | |
| include_directories(
 | |
| # include
 | |
|   ${catkin_INCLUDE_DIRS}
 | |
| )
 | |
| 
 | |
| ## Declare a C++ library
 | |
| # add_library(${PROJECT_NAME}
 | |
| #   src/${PROJECT_NAME}/Aee1220310013.cpp
 | |
| # )
 | |
| 
 | |
| ## Add cmake target dependencies of the library
 | |
| ## as an example, code may need to be generated before libraries
 | |
| ## either from message generation or dynamic reconfigure
 | |
| # add_dependencies(${PROJECT_NAME} ${${PROJECT_NAME}_EXPORTED_TARGETS} ${catkin_EXPORTED_TARGETS})
 | |
| 
 | |
| ## Declare a C++ executable
 | |
| ## With catkin_make all packages are built within a single CMake context
 | |
| ## The recommended prefix ensures that target names across packages don't collide
 | |
| # add_executable(${PROJECT_NAME}_node src/Aee1220310013_node.cpp)
 | |
| 
 | |
| ## Rename C++ executable without prefix
 | |
| ## The above recommended prefix causes long target names, the following renames the
 | |
| ## target back to the shorter version for ease of user use
 | |
| ## e.g. "rosrun someones_pkg node" instead of "rosrun someones_pkg someones_pkg_node"
 | |
| # set_target_properties(${PROJECT_NAME}_node PROPERTIES OUTPUT_NAME node PREFIX "")
 | |
| 
 | |
| ## Add cmake target dependencies of the executable
 | |
| ## same as for the library above
 | |
| # add_dependencies(${PROJECT_NAME}_node ${${PROJECT_NAME}_EXPORTED_TARGETS} ${catkin_EXPORTED_TARGETS})
 | |
| 
 | |
| ## Specify libraries to link a library or executable target against
 | |
| # target_link_libraries(${PROJECT_NAME}_node
 | |
| #   ${catkin_LIBRARIES}
 | |
| # )
 | |
| 
 | |
| #############
 | |
| ## Install ##
 | |
| #############
 | |
| 
 | |
| # all install targets should use catkin DESTINATION variables
 | |
| # See http://ros.org/doc/api/catkin/html/adv_user_guide/variables.html
 | |
| 
 | |
| ## Mark executable scripts (Python etc.) for installation
 | |
| ## in contrast to setup.py, you can choose the destination
 | |
| # catkin_install_python(PROGRAMS
 | |
| #   scripts/my_python_script
 | |
| #   DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
 | |
| # )
 | |
| 
 | |
| ## Mark executables for installation
 | |
| ## See http://docs.ros.org/melodic/api/catkin/html/howto/format1/building_executables.html
 | |
| # install(TARGETS ${PROJECT_NAME}_node
 | |
| #   RUNTIME DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
 | |
| # )
 | |
| 
 | |
| ## Mark libraries for installation
 | |
| ## See http://docs.ros.org/melodic/api/catkin/html/howto/format1/building_libraries.html
 | |
| # install(TARGETS ${PROJECT_NAME}
 | |
| #   ARCHIVE DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION}
 | |
| #   LIBRARY DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION}
 | |
| #   RUNTIME DESTINATION ${CATKIN_GLOBAL_BIN_DESTINATION}
 | |
| # )
 | |
| 
 | |
| ## Mark cpp header files for installation
 | |
| # install(DIRECTORY include/${PROJECT_NAME}/
 | |
| #   DESTINATION ${CATKIN_PACKAGE_INCLUDE_DESTINATION}
 | |
| #   FILES_MATCHING PATTERN "*.h"
 | |
| #   PATTERN ".svn" EXCLUDE
 | |
| # )
 | |
| 
 | |
| ## Mark other files for installation (e.g. launch and bag files, etc.)
 | |
| # install(FILES
 | |
| #   # myfile1
 | |
| #   # myfile2
 | |
| #   DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}
 | |
| # )
 | |
| 
 | |
| #############
 | |
| ## Testing ##
 | |
| #############
 | |
| 
 | |
| ## Add gtest based cpp test target and link libraries
 | |
| # catkin_add_gtest(${PROJECT_NAME}-test test/test_Aee1220310013.cpp)
 | |
| # if(TARGET ${PROJECT_NAME}-test)
 | |
| #   target_link_libraries(${PROJECT_NAME}-test ${PROJECT_NAME})
 | |
| # endif()
 | |
| 
 | |
| ## Add folders to be run by python nosetests
 | |
| # catkin_add_nosetests(test)
 |