git总结

来源:互联网 发布:js访问url 不跳转 编辑:程序博客网 时间:2024/04/29 20:20
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 $*
//////////////////////////////////////////////////////////////



0 0
原创粉丝点击