您的位置:首页 > 其它

git总结

2016-04-28 19:21 288 查看
ssh-keygen -t rsa

eval "$(ssh-agent -s)"

ssh-add ~/.ssh/id_rsa

git config --global review."server:8080/gerrit".username tester

git config --global user.name tester

git config --global user.email tester@server.com

git config --global core.editor vim

git config --global core.preloadindex true

git config -l

git log  按提交时间列出所有的更新,最近的更新排在最上面。

git log -p  展开显示每次提交的内容差异。

git log -p -2  展开显示每次提交的内容差异,用-2则仅显示最近的两次更新。

git log --stat  仅显示简要的增改行数统计。

git log --shortstat  只显示 --stat 中最后的行数修改添加移除统计。

git log --name-only  仅在提交信息后显示已修改的文件清单。

git log --name-status  显示新增、修改、删除的文件清单。

git log --abbrev-commit  仅显示 SHA-1 的前几个字符,而非所有的40个字符。

git log --relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。

git log --graph  显示ASCII图形表示的分支合并历史。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。

git log --since=2.weeks

**常用的类似选项

选项 说明

-(n) 仅显示最近的 n 条提交

--since, --after 仅显示指定时间之后的提交。

--until, --before 仅显示指定时间之前的提交。

--author 仅显示指定作者相关的提交。

--committer 仅显示指定提交者相关的提交。

**--pretty  指定使用完全不同于默认格式的方式展示提交历史

git log --pretty=oneline  将每个提交放在一行显示,这在提交数很大时非常有用。

or 

git log --pretty=oneline filename

git log --pretty=format:"%h - %an, %ar : %s"  可以定制要显示的记录格式,这样的输出便于后期编程提取分析。

**

选项 说明

%H 提交对象(commit)的完整哈希字串

%h 提交对象的简短哈希字串

%T 树对象(tree)的完整哈希字串

%t 树对象的简短哈希字串

%P 父对象(parent)的完整哈希字串

%p 父对象的简短哈希字串

%an 作者(author)的名字

%ae 作者的电子邮件地址

%ad 作者修订日期(可以用 -date= 选项定制格式)

%ar 作者修订日期,按多久以前的方式显示

%cn 提交者(committer)的名字

%ce 提交者的电子邮件地址

%cd 提交日期

%cr 提交日期,按多久以前的方式显示

%s 提交说明

git log --pretty=format:"%h %s" --graph  可以看到开头多出一些 ASCII 字符串表示的简单图形,形象地展示了每个提交所在的分支及其分化衍合情况。

gitk  图形化工具查阅提交历史

还可以给出若干搜索条件,列出符合的提交。用--author选项显示指定作者的提交,用 --grep 选项搜索提交说明中的关键字。(请注意,如果要得到同时满足这两个选项搜索条件的提交,就必须用--all-match 选项。)

如果只关心某些文件或者目录的历史提交,可以在 git log 选项的最后指定它们的路径。因为是放在最后位置上的选项,所以用两个短划线(--)隔开之前的选项和后面限定的路径名。

例子,如果要查看 Git 仓库中,2008 年 10 月期间,Junio Hamano 提交的但未合并的测试脚本(位于项目的 t/ 目录下的文件),可以用下面的查询命令:

$ git log --pretty="%h - %s" --author=gitster --since="2008-10-01" \

   --before="2008-11-01" --no-merges -- t/

5610e3b - Fix testcase failure when extended attribute

acd3b9e - Enhance hold_lock_file_for_{update,append}()

f563754 - demonstrate breakage of detached checkout wi

d1a43f2 - reset --hard/read-tree --reset -u: remove un

51a94af - Fix "checkout --track -b newbranch" on detac

b0ad11e - pull: allow "git pull origin $something:$cur

$ git show a3121db06affe369d37cdd07815423b947c

2个外部工具:

extDiff

//////////////////////////////////////////////////////////////

#!/bin/sh

echo $*

[ $# -eq 7 ] && p4merge "$2" "$5"

//////////////////////////////////////////////////////////////

extMerge

//////////////////////////////////////////////////////////////

#!/bin/sh

p4merge $*

//////////////////////////////////////////////////////////////
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: