我如何查看我所做的任何尚未推送到远程存储库的本地提交?有时,git状态会显示我的分支是在origin/master之前提交的X,但并不总是这样。
这是我安装Git的bug,还是我遗漏了什么?
我如何查看我所做的任何尚未推送到远程存储库的本地提交?有时,git状态会显示我的分支是在origin/master之前提交的X,但并不总是这样。
这是我安装Git的bug,还是我遗漏了什么?
当前回答
如上所述:
git diff origin/master。。头部
但如果您使用的是gitgui
打开gui界面后,选择“Repository”->在“Visualize History”下
注意:有些人喜欢使用CMDPrompt/Terminal,而有些人则喜欢使用GitGUI(为了简单起见)
其他回答
这是我的可移植解决方案(shell脚本也适用于Windows,无需额外安装),它显示了所有分支与原始分支的区别:git fetch log
示例输出:
==== branch [behind 1]
> commit 652b883 (origin/branch)
| Author: BimbaLaszlo <bimbalaszlo@gmail.com>
| Date: 2016-03-10 09:11:11 +0100
|
| Commit on remote
|
o commit 2304667 (branch)
Author: BimbaLaszlo <bimbalaszlo@gmail.com>
Date: 2015-08-28 13:21:13 +0200
Commit on local
==== master [ahead 1]
< commit 280ccf8 (master)
| Author: BimbaLaszlo <bimbalaszlo@gmail.com>
| Date: 2016-03-25 21:42:55 +0100
|
| Commit on local
|
o commit 2369465 (origin/master, origin/HEAD)
Author: BimbaLaszlo <bimbalaszlo@gmail.com>
Date: 2016-03-10 09:02:52 +0100
Commit on remote
==== test [ahead 1, behind 1]
< commit 83a3161 (test)
| Author: BimbaLaszlo <bimbalaszlo@gmail.com>
| Date: 2016-03-25 22:50:00 +0100
|
| Diverged from remote
|
| > commit 4aafec7 (origin/test)
|/ Author: BimbaLaszlo <bimbalaszlo@gmail.com>
| Date: 2016-03-14 10:34:28 +0100
|
| Pushed remote
|
o commit 0fccef3
Author: BimbaLaszlo <bimbalaszlo@gmail.com>
Date: 2015-09-03 10:33:39 +0200
Last common commit
可以使用为日志传递的参数,例如--oneline或--patch。
git show
将显示本地提交中的所有差异。
git show --name-only
将显示本地提交id和提交名称。
这给出了origin/master和HEAD之间所有提交的日志:
git log origin/master..HEAD
当HEAD位于主分支上时,这将提供未推送提交的日志。
同样,要查看差异:
git diff origin/master..HEAD
所有其他答案都是关于“上游”(你从中选择的分支)。但是一个本地分支可以推到一个不同于它所从的分支。
主机可能不会推送到远程跟踪分支“origin/master”。master的上游分支可能是origin/master,但它可以推送到远程跟踪分支origin/xxx或甚至另一个UpstreamRepo/yyy。这些值由当前分支的branch.*.pushremote以及全局remote.pushDefault值设置。
在查找未推送的提交时,重要的是远程跟踪分支:在本地分支将被推送到的远程跟踪分支。远程的分支也可以是origin/xxx,甚至是另一个UpstreamRepo/yyy。
Git2.5+(2015年第二季度)引入了一个新的快捷方式:<branch>@{push}
请参见Jeff King(peff)提交的提交29bc885、提交3dbe9db、提交adfe5d0、提交48c5847、提交a1ad0eb、提交e291c75、提交979cb24、提交1ca41a1、提交3a429d0、提供a9f9f8c、提交8770e6f、提交da66b27、提交f052154、提交9e3751d、提交ee2499f[均自2015年5月21日起]和提交e41bf35[2015月1日]。(2015年6月5日,Junio C Hamano--gitster在提交c4a8354中合并)
提交adfe5d0解释:
sha1_name:实现@{push}速记
在三角工作流中,每个分支可能有两个不同的兴趣点:通常从中提取的@{upstream}和通常推送到的目的地。后者没有简写,但有它很有用。例如,您可能想知道哪些提交没有已推送:git-log@{push}。。或者作为一个更复杂的示例,假设您通常从origin/master(您将其设置为@{upstream})拉取更改,并将更改推送到fork(例如,myfork/topic)。您可能会从多台机器推送到分叉,要求您从推送目的地(而不是上游)集成更改。使用此修补程序,您只需执行以下操作:gitrebase@{push}而不是键入全名。
提交29bc885增加了:
对于每个引用:接受“%(push)”格式
正如我们有“%(upstream)”来报告每个ref的“@{upstream}”一样,这个补丁添加了“%(push)”以匹配“@{push}”。它支持与上游相同的跟踪格式修饰符(例如,因为您可能想知道哪些分支具有要推送的提交)。
如果您想查看与您要推送的分支相比,您的本地分支领先/落后的提交数量:
git for-each-ref --format="%(refname:short) %(push:track)" refs/heads
显示本地但非上游的所有提交:
git log @{u}..
@{u} 或@{upstream}表示当前分支的上游分支(有关详细信息,请参阅git-rev-parse-help或git-help修订版)。