我想获得Git存储库的提交数量,有点像SVN的修订号。
我们的目标是将其用作唯一的、递增的构建号。
我目前这样做,在Unix/Cygwin/msysGit上:
git log --pretty=format:'' | wc -l
但我觉得它有点过时了。
有更好的办法吗?如果我实际上不需要wc甚至Git,那么它就可以在裸Windows上工作,那就太棒了。只要读取一个文件或目录结构…
我想获得Git存储库的提交数量,有点像SVN的修订号。
我们的目标是将其用作唯一的、递增的构建号。
我目前这样做,在Unix/Cygwin/msysGit上:
git log --pretty=format:'' | wc -l
但我觉得它有点过时了。
有更好的办法吗?如果我实际上不需要wc甚至Git,那么它就可以在裸Windows上工作,那就太棒了。只要读取一个文件或目录结构…
当前回答
如果你只使用一个分支,比如master,我认为这会很好:
git rev-list --full-history --all | wc -l
这将只输出一个数字。你可以将它别名为
git revno
让事情变得更方便。要做到这一点,编辑你的.git/配置文件,并添加到:
[alias]
revno = "!git rev-list --full-history --all | wc -l"
这将不能在Windows上工作。我不知道该操作系统的“wc”对应的是什么,但编写一个Python脚本来为您进行计数将是一个多平台解决方案。
编辑:获得两次提交之间的计数:
我正在寻找一个答案,该答案将显示如何获得两个任意修订之间的提交数,但没有看到任何答案。
git rev-list --count [older-commit]..[newer-commit]
其他回答
使用Bash语法,
$(git rev-list --count HEAD)
对于纯线性历史来说还好。如果你有时也想从分支中获得“数字”(基于master),考虑:
$(git rev-list --count $(git merge-base master HEAD)).$(git rev-list --count ^master HEAD)
当从master签出运行时,您得到的只是1234.0或类似的结果。当从分支的签出运行时,如果在该分支上已经进行了13次提交,那么您将得到类似于1234.13的结果。显然,这只在你基于一个给定的主修订的最多一个分支时有用。
first-parent可以加入到微号中,以抑制一些合并其他分支时产生的提交,尽管这可能是不必要的。
在我们公司,我们从SVN转移到Git。缺乏修订数字是一个大问题!
执行git svn clone,然后用它的svn修订号标记上一次提交的svn:
export hr=`git svn find-rev HEAD`
git tag "$hr" -f HEAD
然后你可以在的帮助下得到修订号
git describe --tags --long
这个命令会给出如下内容:
7603-3-g7f4610d
含义:最后一个标签是7603 -这是SVN的修订。3 -是从它提交的计数。我们需要把它们加起来。
因此,修订号可以通过以下脚本计算:
expr $(git describe --tags --long | cut -d '-' -f 1) + $(git describe --tags --long | cut -d '-' -f 2)
获取一个修订的提交计数(HEAD, master,一个提交哈希):
git rev-list --count <revision>
要获得所有分支的提交计数:
git rev-list --all --count
我不建议将此用于构建标识符,但如果必须,最好将此计数用于构建所针对的分支。这样,相同的修订将总是有相同的数字。如果对所有分支使用该计数,其他分支上的活动可能会改变该数字。
你可以用:
git shortlog -s -n
结果:
827 user one
15 user two
2 Gest
有一个很好的帮助脚本,Git人员使用它来帮助生成一个基于Git描述的有用的版本号。我展示了脚本,并在回答如何在Git项目的文件中包含当前提交id时解释了它。