Skip to content
This repository has been archived by the owner on Sep 29, 2024. It is now read-only.

tinkerfuroc/tinker2014

Repository files navigation

tinker2014

tinker2014 Build Status


#目前有的包

##driver工作空间

####d_say 发出声音

####d_cv 将primesense采集的图像转换为opencv格式

####d_pcl pcl相关驱动

####d_firmware 固件操作与通讯

##logic工作空间

####l_sphinx_wrapper 使用pocketsphinx进行语音识别相关

##decision工作空间

####answer_questions 回答问题

##其他

####ui/start 启动脚本, 启动方法是

cd $TINKER_WORKSPACE
./start.py

#重构设想

##文件结构

假设沿用之前的三层架构:

tinker2014/

|-dev/

|-downloaded/

|-driver/

|-logic/

|-decision/

|-navigation/

|-share/

|-ui/

在tinker2014文件夹下放6个catkin workspace, 各自独立开发。

其中downloaded中放下载下来的package, package通过submodule的方式添加到tinker2014版本库中。

dev中放刚创建或临时的package。

navigation是一个submodule, 用来放navigation组使用的package。

downloaded中的package应尽量保持原样。

另外, share文件夹中放资源文件(如*.jpg), ui文件夹中放启动脚本等等非ROS的程序。

目前最上层的编译管理使用Makefile, 但单独编译某个workspace时, 不能自动分析不同workspace之间的依赖来决定是否编译其他workspace。

##使用方法

####配置

按此方法下载tinker2014的源码:

cd ~
git clone https://github.com/<YOUR_NAME>/tinker2014
cd tinker2014
git submodule init
git submodule update   # 克隆子模块

在.bashrc中添加以下内容:

source ~/tinker2014/tinkersetup.bash

注:如果使用的不是bash, 需要在此之前设置 TINKER_WORKSPACE=~/tinker2014

建议在.bashrc中添加:

ROS_WORKSPACE=$TINKER_WORKSPACE

之后先完整编译一次,再做别的操作。

####编译

与直接使用catkin管理ROS工作空间类似, TINKER_WORKSPACE下执行make相当于在各工作空间执行catkin_make, 执行make clean相当于在各工作空间执行catkin_make clean。 也支持make dev或make clean_dev等用法。 可以只编译指定的package。

make                # 全部编译
make driver         # 编译driver workspace
make dev pkg=d_cv   # 编译指定package
make driver pkg="d_cv d_pcl"
make clean          # 全部清理
make clean_driver   # 清理driver workspace

##命名规则

目前存在不常用的package、node很难找的情况。 暂时规定命名规则:

####package

命名前可以到这个网站看有没有同名的package: http://www.ros.org/browse/list.php

  • downloaded中的package保留原名

  • driver中的package以d开头, 然后按 ROS建议的方法命名: 所有字母小写, 以下划线分隔, 如d_serial

  • logic中的package以l开头, 然后按 ROS建议的方法命名: 所有字母小写, 以下划线分隔, 如l_parser

  • decision中的package直接按 ROS建议的方法命名, 如answer_questions

  • navigation中自建的package以nv开头, 然后按 ROS建议到方法命名: 所有字母小写, 以下划线分隔, 如nv_fake_scan

  • navigation中下载的package保持原名

####node

  • 按ROS建议的方式命名: 所有字母小写, 以下划线分隔

  • 建议保留用于单元测试的node,命名时加上test_前缀

####topic与service

  • 名字分为两部分,前半部分为去掉d_或l_前缀的package名,后半部分为该topic名。

  • topic名所有字母小写, 以下划线分隔

  • 如d_say订阅的某topic可命名为/say/sentence

####message

  • message名按大驼峰法命名,如DoorStatus.msg

  • 内部的变量名按小写加下划线命名,如is_open

  • 声明message的位置待讨论

##协作模式

依然是Fork+Pull的模式。

代码开发都在dev等分支下进行, 开发好后将dev分支合并到主帐户(tinkerfuroc)的master分支(pull request)。 其他帐户的master分支用于同步主帐户master分支的更改。

临时的修改之类的先放在dev workspace里。

具体可以按照此流程进行:

  1. https://github.com/tinkerfuroc/tinker2014 Fork版本库到自己的帐户下
  2. git clone
  3. 创建并推送自己的dev分支:
cd tinker2014
git checkout -b dev
echo -e '[branch "dev"]\n    remote = origin\n    merge = refs/heads/dev' >> .git/config
git push origin dev
  • 如果在自己的github帐户上已经有dev分支,则可以这样操作:
git branch -va    # 检查是否确实有远程dev分支(有时候会不显示,不过没关系)
git checkout -b dev remotes/origin/dev
# 这时 .git/config 应该已经被自动修改了
  1. 在dev分支下开发(可以合理使用git的分支机制做一些更复杂的操作)
  2. 将自己的dev分支推送到tinkerfuroc下的master分支(pull request):
  • 到github页面上,切换到dev分支,点创建pull request
  • pull request的路径应是 tinkerfuroc:master ... YOUR_NAME:dev
  • 认真填写改动说明后提交
  • tinkerfuroc:master分支更新后,创建一个路径为 YOUR_NAME:master ... tinkerfuroc:master 的pull request,并自己合并之
  • 再依据YOUR_NAME:master更新YOUR_NAME:dev,创建pull request或者删了重建都可以