ROS学习笔记(四)

ROS学习笔记(四)——自定义程序包

本部分教程将剖析catkin_create_pkg命令生成的每个文件并详细描述这些文件的组成部分以及如何自定义这些文件。

自定义package.xml文件

我们前面说过一个功能包的清单由一个名为package.xml的文件管理,我们先来看一个自动生成的package.xml文件


<package format="2">
  <name>beginner_tutorialsname>
  <version>0.0.0version>
  <description>The beginner_tutorials packagedescription>

  
  
  
  <maintainer email="[email protected]">blvindonmaintainer>


  
  
  
  <license>TODOlicense>


  
  
  
  


  
  
  
  


  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  <buildtool_depend>catkinbuildtool_depend>
  <build_depend>roscppbuild_depend>
  <build_depend>rospybuild_depend>
  <build_depend>std_msgsbuild_depend>
  <build_export_depend>roscppbuild_export_depend>
  <build_export_depend>rospybuild_export_depend>
  <build_export_depend>std_msgsbuild_export_depend>
  <exec_depend>roscppexec_depend>
  <exec_depend>rospyexec_depend>
  <exec_depend>std_msgsexec_depend>


  
  <export>
    

  export>
package>
  • 描述标签
    首先更新描述标签:
    The beginner_tutorials package
    将描述信息修改为任何你喜欢的内容,但是按照约定第一句话应该简短一些,因为它覆盖了程序包的范围。如果用一句话难以描述完全那就需要换行了。
    如自动生成的package.xml文件中的标签中的内容为:The beginner_tutorials package
  • 维护者标签
   
  
  
  <maintainer email="[email protected]">blvindonmaintainer>

这是package.xml中要求填写的一个重要标签,因为它能够让其他人联系到程序包的相关人员。至少需要填写一个维护者名称,但如果有需要的话你可以添加多个。除了在标签里面填写维护者的名称外,还应该在标签的email属性中填写邮箱地址,可以写成:
blvindon

  • 许可标签

  
  
  <license>TODOlicense>

你应该选择一种许可协议并将它填写到这里。一些常见的开源许可协议有BSD、MIT、Boost Software License、GPLv2、GPLv3、LGPLv2.1和LGPLv3。你可以在Open Source Initiative中阅读其中的若干个许可协议的相关信息。http://wiki.ros.org/ROS/Tutorials/NavigatingTheFilesystem使用BSD协议,因为ROS核心组件的剩余部分已经使用了该协议:
BSD
上面那个自动生成的package.xml文件中的是:
TODO
- 依赖项标签
接下来的标签用来描述程序包的各种依赖项,这些依赖项分为build_depend、buildtool_depend、run_depend、test_depend。关于这些标签的更详细介绍请参考Catkin Dependencies相关的文档。

 
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  

在之前的操作中,因为我将 std_msgs、 roscpp、 和 rospy作为catkin_create_pkg命令的参数,
$ catkin_create_pkg beginner_tutorials std_msgs rospy roscpp
所以生成的依赖项看起来如下:

 <buildtool_depend>catkinbuildtool_depend>
  <build_depend>roscppbuild_depend>
  <build_depend>rospybuild_depend>
  <build_depend>std_msgsbuild_depend>
  <build_export_depend>roscppbuild_export_depend>
  <build_export_depend>rospybuild_export_depend>
  <build_export_depend>std_msgsbuild_export_depend>

除了catkin中默认提供的buildtool_depend,所有我们列出的依赖包都已经被添加到build_depend标签中。在本例中,因为在编译和运行时我们需要用到所有指定的依赖包,因此还需要将每一个依赖包分别添加到run_depend标签中:

  export_depend>roscppexport_depend>
  export_depend>rospyexport_depend>
  export_depend>std_msgsexport_depend>
  <exec_depend>roscppexec_depend>
  <exec_depend>rospyexec_depend>
  <exec_depend>std_msgsexec_depend>
  • 最后完成的 package.xml
    现在看下面最后去掉了注释和未使用标签后的package.xml文件就显得更加简洁了:
   1 
   2 <package format="2">
   3   <name>beginner_tutorialsname>
   4   <version>0.1.0version>
   5   <description>The beginner_tutorials packagedescription>
   6 
   7   <maintainer email="[email protected]">Your Namemaintainer>
   8   <license>BSDlicense>
   9   <url type="website">http://wiki.ros.org/beginner_tutorialsurl>
  10   <author email="[email protected]">Jane Doeauthor>
  11 
  12   <buildtool_depend>catkinbuildtool_depend>
  13 
  14   <build_depend>roscppbuild_depend>
  15   <build_depend>rospybuild_depend>
  16   <build_depend>std_msgsbuild_depend>
  17 
  18   <exec_depend>roscppexec_depend>
  19   <exec_depend>rospyexec_depend>
  20   <exec_depend>std_msgsexec_depend>
  21 
  22 package>

自定义 CMakeLists.txt

到此,这个包含程序包元信息的package.xml文件已经按照需要完成了裁剪整理,现在你可以继续下面的教程了。catkin_create_pkg命令生成的CMakeLists.txt文件将在后续关于编译ROS程序代码的教程中讲述。

你可能感兴趣的:(ROS学习笔记)