我已经找到了这个答案:在git的分支上提交的数量 但这假设分支是从master创建的。
我如何在不依赖于这个假设的情况下计算沿着分支提交的数量呢?
在SVN中,这是微不足道的,但由于某种原因,在git中很难解决。
我已经找到了这个答案:在git的分支上提交的数量 但这假设分支是从master创建的。
我如何在不依赖于这个假设的情况下计算沿着分支提交的数量呢?
在SVN中,这是微不足道的,但由于某种原因,在git中很难解决。
当前回答
从历史开始到当前分支的提交量,不包括来自合并分支的提交量:
git rev-list HEAD --count --first-parent
从文档git rev-list——help:
——“首席家长 在看到合并提交时,只遵循第一个父提交。在查看特定主题分支的演变时,此选项可以提供更好的概述,因为合并到主题分支往往只是为了不时地调整到更新的上游,并且此选项允许您忽略通过这种合并引入历史记录的单个提交。不能与——bisect组合。
注意:浅克隆会缩小历史大小。例如,如果你用深度1克隆,将返回1。
自其他提交以来已完成的提交数:
git rev-list HEAD abc0923f --count --first-parent
或相同:
git rev-list abc0923f.. --count --first-parent
或者使用其他git引用:
git rev-list master tag-v20 --count --first-parent
统计自2018年以来已完成的任务
git rev-list HEAD --count --first-parent --since=2018-01-01
01-01-2018, 01.01.2018, 2018.01.01也适用。
git rev-label
我写了一个脚本,从Git中获得版本修订,格式为'$refname-c$count-g$short$_dirty',扩展为master-c137-gabd32ef。 帮助包含在脚本本身中。
其他回答
git log——pretty=oneline | wc -l怎么样
这将从当前分支的角度计算所有提交。
你也可以 Git log | grep commit | wc -l
然后得到结果
你可以在git bash/unix上使用awk命令来获取提交的数量。
git shortlog -s -n | awk '/Author/ { print $1 }'
因为OP引用了git中分支上的提交数量,我想补充的是,这里给出的答案也适用于任何其他分支,至少从git 2.17.1版本开始(似乎比Peter van der Does的答案更可靠):
正常工作:
git checkout current-development-branch
git rev-list --no-merges --count master..
62
git checkout -b testbranch_2
git rev-list --no-merges --count current-development-branch..
0
最后一个命令像预期的那样给出零提交,因为我刚刚创建了分支。前面的命令给出了开发分支上的实际提交数减去合并提交数
工作不正常:
git checkout current-development-branch
git rev-list --no-merges --count HEAD
361
git checkout -b testbranch_1
git rev-list --no-merges --count HEAD
361
在这两种情况下,我都得到了开发分支和master中所有提交的数量。
如果您使用的是UNIX系统,则可以这样做
git log|grep "Author"|wc -l