# 增加子模块
$ git submodule add url/to/submodule/rep workspace/dir
# 第一次clone下来时运行一次init和update
$ git submodule init
$ git submodule update
# 注意其中的update是将子模块的版本更新到当前主版本使用的子版本的版本。如子模
# 块有三个版本A,B,C,现在父版本使用的子模块的B版本。那么update只会签出B版本,
# 不会签出最新的C版本。如果要签出最新的版本,要到子模块目录运行:
$ cd dir/to/submodule
$ git pull
# 在修改子模块前最好在子模块下建立一个分支或切换到开发分支
$ git checkout master
# 子模块有提交时也要到该目录下, 确定当前有分支时进行提交
$ cd dir/to/submodule
$ git commit -m "desc"
# 如果不小心在没有分支的情况下提交了,然后又切换到了新的分支,那么之前的修改
# 可能都看不到了。比如在没有分支的情况下提交了,然后又checkout了一个分支:
$ git checkout issue2
Warning: you are leaving 1 commit behind, not connected to any of your branches:
bada553d My commit message
If you want to keep them by creating a new branch, this may be a good time to do so with:
git branch new_branch_name ....
Branch issue2 set up to track remote branch issue2 from origin.
Switched to a new branch issue2.
# 遇到上边的错误时可以通过以下方式将之前的修改找出来并合并到当前开发分支,使
# 用reflog查看之前的提交。就算没有分支的提交也可以看到。
$ git reflog
# 找到之前提交的版本比如是HEAD@{3},将其签出到分支,然后就可以将它合并到其它分支了
$ git checkout -b tmp HEAD@{3}
$ git submodule add url/to/submodule/rep workspace/dir
# 第一次clone下来时运行一次init和update
$ git submodule init
$ git submodule update
# 注意其中的update是将子模块的版本更新到当前主版本使用的子版本的版本。如子模
# 块有三个版本A,B,C,现在父版本使用的子模块的B版本。那么update只会签出B版本,
# 不会签出最新的C版本。如果要签出最新的版本,要到子模块目录运行:
$ cd dir/to/submodule
$ git pull
# 在修改子模块前最好在子模块下建立一个分支或切换到开发分支
$ git checkout master
# 子模块有提交时也要到该目录下, 确定当前有分支时进行提交
$ cd dir/to/submodule
$ git commit -m "desc"
# 如果不小心在没有分支的情况下提交了,然后又切换到了新的分支,那么之前的修改
# 可能都看不到了。比如在没有分支的情况下提交了,然后又checkout了一个分支:
$ git checkout issue2
Warning: you are leaving 1 commit behind, not connected to any of your branches:
bada553d My commit message
If you want to keep them by creating a new branch, this may be a good time to do so with:
git branch new_branch_name ....
Branch issue2 set up to track remote branch issue2 from origin.
Switched to a new branch issue2.
# 遇到上边的错误时可以通过以下方式将之前的修改找出来并合并到当前开发分支,使
# 用reflog查看之前的提交。就算没有分支的提交也可以看到。
$ git reflog
# 找到之前提交的版本比如是HEAD@{3},将其签出到分支,然后就可以将它合并到其它分支了
$ git checkout -b tmp HEAD@{3}