- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
有没有一种方法可以使用远程分支(比如 origin/branch1)在暂存/未暂存更改之间执行 git diff。 git difftool 有类似的选项吗?
或
有没有办法通过 git 远程分支来区分本地文件系统中的更改(忘记暂存或未暂存)?我只想在提交之前检查我的更改。一旦我完成了更改并解决了与远程分支的冲突,这就非常有用。
最佳答案
Is there a way to do a git diff between staged changes and a remote branch say origin/branch1.
只需运行:
git diff --cached origin/branch1
(如果你愿意,你可以在这里使用 --staged
;我使用 --cached
因为 git rm
有 --缓存
但不是--staged
)。这向您展示了一种更改 origin/branch1
以匹配您已上演的内容的方法:
$ git show origin/branch1:README
initial version
$ cat README
initial version
second version
$ echo staged >> README && git add README
$ echo replace whole thing > README
$ cat README
replace whole thing
$ git diff --cached origin/branch1
diff --git a/README b/README
index 42549ca..d9074b8 100644
--- a/README
+++ b/README
@@ -1 +1,3 @@
initial version
+second version
+staged
如果您想了解一种方法来更改已上演的内容以匹配 origin/branch1
,请添加 -R
(颠倒顺序):
$ git diff -R --cached origin/branch1
diff --git b/README a/README
index d9074b8..42549ca 100644
--- b/README
+++ a/README
@@ -1,3 +1 @@
initial version
-second version
-staged
如您所见,这些与不使用 --cached
又名 --staged
的比较有很大不同,但这也很简单:
$ git diff origin/branch1
diff --git a/README b/README
index 42549ca..acb8b7a 100644
--- a/README
+++ b/README
@@ -1 +1 @@
-initial version
+replace whole thing
Is there a similar option with git difftool?
这些相同的选项(--cached
或不缓存,以及使用任何名称来标识任何提交)也可用于 git difftool
。
这里值得记住的是,在 Git 中实际上并没有任何远程分支。您有一些提交,并且您有一些提交的名称。一种可能的名称形式是 远程跟踪名称,例如 origin/branch1
。有些人喜欢称其为“远程分支”,但它只是你自己的(本地)Git 对 origin
的 branch1
指向的位置的内存,当你运行时git fetch origin
并让你的 Git 获取他们的 Git 分支。
关于远程分支的暂存或未暂存更改之间的 Git diff,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47585962/
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 3年前关闭。 Improve this questi
我正在寻找有关自动文件夹同步工具的建议,以保持我们三个环境中的内容自动同步。 具体来说,我们有几个应用程序,用户可以在其中上传内容(通过文件上传页面或类似机制),例如图像、pdf 文件、word 文档
我是 Azure 新手,我正在开发一个使用新网站模型而不是云服务的项目。我想建立一个像这样的持续交付流程:http://www.windowsazure.com/en-us/develop/net/c
我正在寻找这两者在 GPU 读取速度和偶尔 CPU 写入(每帧少于一次,甚至只有一次)方面的区别。我不想使用 D3D11_USAGE_DYNAMIC,因为数据不会更新 >= 每帧一次。 Default
我有一个网站 www.livesite.com 目前正在运行。我一直在用 http://localhost 在本地机器上开发网站的新版本然后使用 svn 将我的更改提交到 www.testsite.c
我正在尝试创建一个在开发环境(将计算机用作本地主机)、暂存环境(服务器上的特定端点)和生产环境(另一个特定服务器端点)中工作的 Xcode 项目。我找到了一些关于如何设置它的不同教程。一些解决方案建议
在我过去和现在的 Web 开发职位中,Staging/Beta 和 Production/Stable 环境共享一个数据库。 这是我对正在发生的事情的理解: Staging/Beta 基本上与 Pr
在 WebsiteAzure 中,我们有一个暂存功能。因此,我们可以部署到一个暂存站点,对其进行测试,填充所有缓存,然后使用暂存站点切换生产。 现在如何在带有 IIS 的普通 Windows 服务器上
昨天,当我们尝试更换我们的舞台制作角色时,遇到了可怕的问题/经历。 这是我们的设置: 我们有一个工作角色从队列中获取消息。这些消息在角色上进行处理。 (表存储插入、数据库选择等)。每个队列消息可能需要
我的 Eclipse 中有一个新的 Git 项目,Staging View 的 Unstaged Changes 面板不仅显示了我正在处理的文件,还显示了 .classpath 和 .project,
这就是我想要做的:在我的工作中,我们目前有多个环境可以工作。我们有多个开发环境,一个用于暂存(我们称之为“预生产”),以及我们的生产实例。我们已经开始在 Vue 中为我们的前端工作,并使用 webpa
假设我在一个文件夹中启动了一个 git 存储库,其中有几个子目录。 我有几个 globbing 模式 .gitignore 来排除子目录中的文件。但是,当我执行 git status 在我暂存任何内容
显然这是一个常见问题:我们有由 git 或其他 SCM 管理的 PHP Web 应用程序,并且(理想情况下)部署在 3 个以上应该极其相似的不同环境中。唯一的区别应该是在特定的配置上,例如外部资源的寻
如何在 Xamarin Forms 应用程序中设置不同的环境? (制作、演出、开发) 目前,我在代码中使用 #if DEBUG 来区分开发过程中使用的代码部分。那么有没有更好的方法来区分不同的环境呢?
如何在 Xamarin Forms 应用程序中设置不同的环境? (制作、演出、开发) 目前,我在代码中使用 #if DEBUG 来区分开发过程中使用的代码部分。那么有没有更好的方法来区分不同的环境呢?
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 4 个月前。 社区在 4
我创建了一个文件,然后使用 git add 将其暂存到我的 git 存储库中. 我还想在同一个提交中删除一些文件,所以做了一个 git rm -f 'files.*' . 我在删除行中使用的通配符有
有没有办法找到我设置为“假设未更改”的文件? 我已经修改了几个文件并想 pull ,所以我将它们设置为“假定不变”。现在我已经完成并想要提交,但是它们没有出现在 Git Staging 窗口中。 我使
我希望使用 Xcode 的方案来确定要针对哪个服务器运行我的应用程序。我有一个从服务器获取信息的应用程序。像大多数人一样,我有一个开发服务器、一个临时服务器和一个生产服务器。 我希望为其中的每一个创建
我希望 merge 一个允许我执行以下操作的 Web 开发工作流程: 在本地开发/测试 模拟生产服务器(许多子域,一些 mysql 数据库) 在台式机和笔记本电脑之间保持同步,以实现移动开发 轻松推送
我是一名优秀的程序员,十分优秀!