git

Git学习笔记(6) -- 独立开发者所用的命令(b)

Posted by Elton's Blog on July 22, 2009

git commit 将当前在index中变化的内容提交到仓库(repository)中 语法:

git commit [-a | --interactive] [-s] [-v] [-u] [--amend] [(-c | -C) ] [-F  | -m ] [--allow-empty] [--no-verify] [-e] [--author=] [--cleanup=] [--] [[-i | -o ]…]
  1. 使用git add命令可以持续的将变动或者新增的内容添加到index中。
  2. 使用git rm 可以将文件从woking tree和index中移除。
  3. 作为参数列在后面的文件,将忽略在index中的变化,而直接使用当前的内容作为提交内容。(例如你之前add过这个文件,但是在add后,又修改过且没有再次add)
  4. 使用-a参数就自动将所有变化的文件执行add操作(这些文件曾经都被add到index中),并将所有在working tree中移除的文件从Index中移除,之后再进行commit

git-reset 重置当前HEAD到指定的状态 适合与你发现刚才作的一些操作是错误的,要Undo一些操作 语法:

git reset [--mixed | --soft | --hard | --merge] [-q] [] 
git reset [-q] [] [--] …
</pre>
--soft,表示不变更working tree和index
--hard,表示working tree和index一同变更

例子:
Undo一个commit再Redo
$ git commit ...
$ git reset --soft HEAD^      回退到上一次commit,并不改变workingtree和index
编辑一些内容
$ git commit -a -c ORIG_HEAD  再次按照原来的HEAD的注释提交,-c表示使用原来的commit时候的注释
永久的回退
$ git commit ...
$ git reset --hard HEAD~3   //永久删掉HEAD,HEAD^和HEAD~2三个版本
git checkout 切换当前分支 git checkout 切换到分支 git checkout -b 建立新分支并切换上去 git checkout -b v2 从某一个start point开始创建新分支,并切换上去 git checkout v2.3 将当前HEAD从现有分支上解除,直接指向新的tag版本 1.5以后支持。 例子: 切换分支到master,将Makefile文件回退两个版本,错误删除了hello.c,再从index中恢复
$ git checkout master             (1)
$ git checkout master~2 Makefile  (2)
$ rm -f hello.c
$ git checkout -- hello.c            (3)