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 $*
//////////////////////////////////////////////////////////////
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 $*
//////////////////////////////////////////////////////////////
相关文章推荐
- 多个约束条件的查询
- 《算法导论》第13章 红黑树
- javascript运行机制之执行顺序详解
- Qt下应用QTcpServer与QTcpSocket实现Tcp控制
- 项目管理(摘抄)
- 搬家了
- lightoj1282 - Leading and Trailing
- centos6.4添加fedora源
- intent
- 异步通信和同步通信
- 数据结构之堆(Heap)的实现
- 【饥荒mod制作吧第六篇】发帖小尾巴教程
- 编译 gcc 5.1 和 6.1
- HTTP返回状态码
- 指针才是C的精髓
- 仿微信联系人列表字母侧滑控件
- 关于手机天气应用中的城市搜索的联想查找方式优化
- 关于软件体系架构的认识
- C#将科大讯飞语音合成文件转换为MULAW音频格式
- 浅谈软件体系架构