- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在分支 master
中有一个文件 foo
。它需要一些工作,所以我创建了分支 bar
,我在那里做了一些工作。事情看起来令人满意,所以我准备 merge 回 master
。只有一个问题:我想保留我在分支 bar
中所做的所有更改以供将来引用,但并非所有更改都属于 master
,反正现在不.但是如果我进行通常的 merge ,git 将看不到任何冲突——因为 master
中的文件 foo
没有被编辑——并且只会进行 merge 。有没有办法强制 git 执行此 merge ,就好像存在我需要解决的冲突一样?或者是否有其他方法可以将 bar
中选定的更改放入 master
中?
最佳答案
有几个选项。直接回答您问题的那个:
git merge --no-commit
将自动 merge 到索引然后停止,就像需要手动解决冲突一样。当然,不会有冲突标记,也没有“未暂存”/等待解决的更改,但您可以在提交前修改提交以查看您想要的样子。
最大的问题是,除了“这可能是一团糟”之外,就 git 而言,bar
中的所有更改都是如此。现在占 master
.由于您暗示您稍后可能需要剩余的更改,所以这不好。
你真正想要的是类似的东西
x --- O --- M <--(master)
\ /
A --- B <--(bar)
哪里O
是原来的分支点,A
有你现在想要的改变,B
具有您稍后需要的更改。
(或者,如果你想避免 merge 提交,你会想要
x --- O --- A <--(master)
\
B <--(bar)
代替。)
如何最好地做到这一点取决于您现在拥有的东西。如果bar
只有一个提交(或者,在任何情况下,如果你很高兴最终只有一个“提交 merge ”和一个“提交保存以备后用”),并且如果 master
上没有提交在 O
之后,你可以这样做:
开始于
x --- O <--(master)
\
AB <--(bar)
你会
git checkout bar
git reset --mixed HEAD^
(假设在 bar
上实际上只有一个提交;否则,将 HEAD^
替换为提交 O
的 SHA1 值或您在提交 O
上放置的标记)。现在你有
x --- O <--(master)(bar)
^HEAD
包含来自 bar
的所有原始更改在你的工作树中未被追踪。因为所有的更改都在一个文件中,所以我们需要使用补丁模式来有选择地添加更改
git add -p
# select the changes to merge
git commit
git stash
给你
x --- O <--(master)
\
A <--(bar)
\ ^HEAD
B <--{stash}
接下来
git checkout master
git merge bar
如果您想要 merge 提交(保留在 bar
上进行更改的拓扑),则传递 --no-ff
到 merge
命令。否则,因为我们假设 master 没有偏离 bar
, 你会得到一个快进离开
x --- O --- A <--(master)(bar)
\ ^HEAD
B <--{stash}
(相反,如果 master
有 分歧但您决定线性化历史,您会将 A
rebase 到 master
而不是 merge ...)
然后你可以做类似的事情
git branch --delete bar
git stash branch bar
结束于
x --- O --- A <--(master)
\
B <--(bar)
关于git - 如何强制 git 进入 "merge conflict mode"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43762558/
我正在开发基于桌面 (Windows 7) 的应用程序,并使用 Qt Creator v 5.6.0 开发程序。我有一个非常奇怪的问题,即 我的程序在 DEBUG 模式下崩溃,但在 RELEASE 模
我爱org-tables ,我用它们来记录各种事情。我现在正在为 Nix 记录一些单行代码(在阅读了 Domen Kožar 的 excellent guide 后,在 this year's Eur
org-mode 是否有一个键绑定(bind)可以在编号/项目符号列表项之间移动,就像您可以对标题一样? 喜欢的功能: org-forward-heading-same-level 大纲下一个可见标题
我知道这有点小,但它一直困扰着我。我正在为一个项目使用 Org-mode,我倾向于经常导出为 PDF 或 HTML,这使我的目录中散落着 PDF、Tex 和 HTML 文件。有没有办法将 Org 模式
有什么方法可以让 org-mode 继续编号列表而不是重新启动? 这是情况。你列了一个类似的列表: Sometimes you can restart the display by doing som
如何在组织模式文件中生成所有标签的枚举列表(例如 :tag:)?假设我有一个以下形式的列表: * Head1 :foo:bar: ** Subhead1 :foo: * Head2
我正在使用 org-mode(Emacs:24.3.1,org-mode: 7.9.3f 8.0.6)作为不同代码片段的数据库语言(目前主要是 elisp 和 python)。这在使用 org-mod
相关问题:org-mode: fontify code blocks natively 截至 2012 年 11 月 1 日,我已经获得了最新的 org-mode 和 emacs 版本(组织存储在 o
有谁知道在使用 ido 模式时区分 dired 模式缓冲区名称与迷你缓冲区中其他类型缓冲区的好方法吗?例如...在 dired 模式缓冲区名称末尾显示正斜杠? 最佳答案 您可以简单地更改dired-m
在这个示例脚本中 import argparse parser = argparse.ArgumentParser() parser.add_argument('--modes', help="tes
我第一次学习“操作系统”。在我的书中,我发现了关于“用户模式”和“内核模式”的这句话: "Switch from user to kernel mode" instruction is execute
我刚刚下载了 Processing 2.0 并尝试从“模式管理器”安装 Android 模式。但是在安装时出现错误提示:“无法将模式“Android 模式”移动到速写本”。我怎样才能摆脱这个错误? 最
在 android L 中,我尝试将相机闪光灯模式设置为 TORCH,它工作正常,但我无法将其更改回闪光灯模式 AUTO 或闪光灯模式 打开。我只能返回闪存模式 OFF。我尝试了像 camera360
有 2 台机器,A 和 B。有 2 个分支,p16 和 c2。 A 有一个 ext3 文件系统,但在 B 上,存档位于带有 vfat 的 truecrypt 驱动器上,mount 显示 rw,uid=
我有 linum-mode在我的 Emacs 配置中全局启用。全局启用意味着它也适用于不受欢迎的速度条。 我为这个问题找到的唯一建议是在存档的 Emacs 帮助邮件列表中,它建议以下 speedbar
Google Cloud Firestore 将很快取代旧的 Google Cloud Datastore。然后可以选择在“ native 模式”或“数据存储模式”下使用 Cloud Firestor
org-mode的版本我的版本 Emacs 附带的(24.5.2) 是 8.2.10 .我已安装版本 8.3.1从 ELPA 并将其添加到我的 init 文件中: (add-to-list 'load
The org-mode manual指出 org-mode 将“”“...在 shell 链接”“”中执行命令,但它不显示此类链接的语法。 我希望能有一个简单完整的示例来说明这种 shell 链接是
我正在尝试在 emacs 24 中使用 dart 模式和 d 模式。如果我单独使用任何一种模式,一切都很好。如果我分别对每种类型的文件使用这两种模式,我在尝试缩进 D 代码时会出错。 以下是在初始化时
我的应用程序中有 CupertinoDatePicker 以使用以下代码选择日期和时间: formatColumn( widget: Consumer( builder: (_, mcProvide
我是一名优秀的程序员,十分优秀!