git 使用总结¶
$ git clone --depth 1 --recursive https://github.com/Valloric/YouCompleteMe.git
OR
$ git clone https://github.com/Valloric/YouCompleteMe.git
$ cd crfasrnn
$ git submodule update --init --recursive
子模块¶
http://stackoverflow.com/questions/2144406/git-shallow-submodules
- 添加子模块
$ git submodule add 仓库地址 路径
- 删除子模块
- 状态
$ git submodule status
- 更新子模块
$ git submodule update --init --recursive
$ git submodule add url path/to/name
$ git submodule init
$ git submodule foreach git pull
$ git submodule update
同步一个COMMIT
可以同步一个commit到本分支
$ git cherry-pick xxx
- Git打TAG
打TAG也就是发布版本
$ git tag -a v1.2 -m “version 1.4” $ git push –tags 如果还不能理解可以到这里看看是linus是怎么给Linux内核打的TAG,TAG看起来像什么:https://github.com/torvalds/linux/releases
# .查看status详情
这样可以在commit之前先看一下修改详情。
$ git add xxx
$ git diff --cached
# .不产生无用的merge的同步 有这么一种情况,用一个分支专门同步代码提供商的代码的时候,如果一般的pull会不断的产生一个merge看起来会很烦,用下边的使用添加一个–rebase就不会产生无用的merge了
$ git pull --rebase origin master
# .关于stash 适用情况:做了修改后,还没有add commit等等后续工作,现在突然要切换分支做其它事情,默认情况下你在这个分支修改的代码会被带到切换过去的分支中。可以先把你修改的保存起来。这些修改可以再还原过来。
$ git stash -u
$ xxxx 随便你的操作
$ git stash pop
注意:-u是代表是也把添加的新文件(术语是未跟踪)也藏起来,一般是要有这个u的。
- # .恢复一个COMMIT
- 如果一个COMMIT你不想要了,想要去除,可以考虑使用以下的方法;
$ git revert xxxx
这个就可以去掉这个COMMIT的改动,这个是明式的去掉,如果你又后悔了,还可以再次恢复。