我如何查看我所做的任何尚未推送到远程存储库的本地提交?有时,git状态会显示我的分支是在origin/master之前提交的X,但并不总是这样。

这是我安装Git的bug,还是我遗漏了什么?


当前回答

git diff origin

假设您的分支被设置为跟踪原点,那么这应该会向您显示差异。

git log origin

将向您提供提交的摘要。

其他回答

所有其他答案都是关于“上游”(你从中选择的分支)。但是一个本地分支可以推到一个不同于它所从的分支。

主机可能不会推送到远程跟踪分支“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 reflog

在那里我找到了我的承诺。

git diff origin

假设您的分支被设置为跟踪原点,那么这应该会向您显示差异。

git log origin

将向您提供提交的摘要。

这是我的可移植解决方案(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 log ^origin/master master