完成git fetch --all --prune
从远程存储库获取引用后,我现在想要查看origin
上每个分支上的最新提交
命令
git for-each-ref --format='%(refname:short)' | grep 'origin/'
列出origin
上的所有16个分支,因此我希望以下命令显示每个分支的最新提交
git for-each-ref --format='%(refname:short)' | grep 'origin/' |
xargs git log --source -n 1
(N.B。当我运行它时,这是一行;为了便于阅读,我将它拆分为两行。)
然而,该命令不起作用,它只列出一个提交:似乎一个提交限制适用于整个列表而不是依次适用于每个分支。
我做错了什么?
(请注意,我还尝试调整解决方案here
git for-each-ref --format='%(refname:short)' | grep 'origin/' |
xargs git show --oneline
但忽略--oneline
标志,结果过于冗长。)
答案 0 :(得分:7)
更简单的解决方案是使用git ls-remote origin
:
git ls-remote --heads origin
例如,在git repo中:
C:\Users\vonc\prog\git\git>git ls-remote --heads origin|
117eea7eaaeb5ecb77d9b7cebdb40b4e85f37374 refs/heads/maint
f5b6079871904ba5b0a8548f91545f126caf898b refs/heads/master
edb03e5a9b9b63d0864557f99f339b2b5f3a9e4e refs/heads/next
014438bc5bdf9deef0d3888e58c9f76addc1106c refs/heads/pu
56f24e80f0af4dd3591c8f143183b59cf9a34620 refs/heads/tmp
33f854ca9eb8251f5b7fa1c670d4abcdd76764ce refs/heads/todo
这将列出最近的提交...甚至没有首先获取!
可以轻松格式化和别名:
C:\Users\vonc\prog\git\git>
git config alias.rh "!git ls-remote -h origin | while read b; do PAGER='' git log -n1 --color --pretty=format:'%ct%C(yellow)%d%Creset - %Cred%h%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset%n' --abbrev-commit $( echo $b | cut -d' ' -f1 ) --; done | sort -rn -k1,10 | cut -c11-"
然后一个简单的git rh会给出:
C:\Users\vonc\prog\git\git>git rh
(origin/master, origin/HEAD) - f5b6079 Second batch for 2.7 (3 months ago) <Junio C Hamano>
(origin/next, next) - edb03e5 Sync with 2.1-rc2 (1 year, 5 months ago) <Junio C Hamano>
(origin/tmp, tmp) - 56f24e8 completion: handle '!f() { ... }; f' and "!sh -c '...' -" aliases (1 year, 7 months ago) <Steffen Prohaska>
(origin/pu) - 014438b Merge branch 'nd/multiple-work-trees' into pu (1 year, 10 months ago) <Junio C Hamano>
(origin/todo) - 33f854c What's cooking (2013/07 #09) (2 years, 5 months ago) <Junio C Hamano>
(tag: v1.8.3.4, origin/maint) - 117eea7 Git 1.8.3.4 (2 years, 6 months ago) <Junio C Hamano>
那是:
此别名假定遥控器名为“origin”。
要使其接受参数it can be changed to a function:
C:\Users\vonc\prog\git\git>git config alias.rh "!f() { git ls-remote -h $1 | while read b; do PAGER='' git log -n1 --pretty=format:'%h%n' --abbrev-commit $( echo $b | cut -d' ' -f1 ) --; done; }; f"
^^
然后:
C:\Users\vonc\prog\git\git>git rh upstream
833e482
7548842
ef7b32d
f67e31e
e2281f4
答案 1 :(得分:4)
问题是git log只打印一个ref的日志,这就是你的xargs调用不起作用的原因。如果你是调用git log -n 1 origin/master origin/not_master
(使用xargs将导致这样的调用)您将获得最新提交的日志,然后该列表仅限于第一个条目。我不知道如果两个分支发生分歧会发生什么,但是,您仍然会将完整的日志输出限制为只有一个条目。
除了VonC的详细答案之外,如果将git log命令包含在循环中而不是使用xargs,则可以修改命令以获得所需的结果:
for ref in $(git for-each-ref --format='%(refname:short)' | grep 'origin/')
do
git --no-pager log $ref -n 1 --oneline
done
使用--no-pager选项将输出直接发送到控制台。
答案 2 :(得分:2)
结合Andrew C对原帖的评论,模式匹配可以包含在git命令中(而不是使用grep),以及andreas-hofmann的观点(在his answer中)xargs正在混淆参数,那么另一个可能的解决方案是
git for-each-ref --format='%(refname:short)' refs/remotes/origin/ | xargs -n1 git log --max-count=1 --source
这将交换模式匹配以在git命令中发生,并告诉xargs一次最多提供一个参数。
(注意:git&#39; s for-each-ref命令中的模式匹配从比赛开始就开始了所以我必须使用&#39; refs / remotes / origin /&#39;而不是模式&g;来源/&#39;我可以使用grep。为了简洁,我可以用-1替换--max-count = 1。)