- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我对git
索引包含的内容与git-add
和git-commit
所包含的内容有一个模糊的想法,但是我不知道当执行git-merge
时这些内容会发生什么。我特别想了解 merge 失败时(例如由于某些冲突)索引的内容。
最佳答案
对于任何给定的路径,索引中最多有四个“版本号”,编号为0(零)到3。我将它们称为“插槽”,就好像它们实际存在于每个条目中一样,然后轻松地进行索引(此索引使它们更容易考虑),尽管实际上只有在需要时才动态引入额外的版本。这些“虚拟插槽”可以为“空”,表示该文件不存在。
(实际上,一旦在索引中创建了一个条目,就会在必要时用一个标志位CE_REMOVED
进行标记。这很麻烦,因为可以将整个文件目录标记为“已删除”,然后可以使用以下名称创建文件:上一个目录并标记为“已添加”。让我们假装我们有固定的插槽,那里是空的,而不是。:-))
插槽#0是“正常”,无冲突,完好无损的条目。它包含一堆缓存数据,路径名和存储在存储库中的文件的blob-ID(SHA-1)。
merge 成功后,一切都是“照常进行”,因此唯一的特殊情况是发生冲突的 merge 。当插槽1、2和/或3不为空时, merge 是“冲突的”。跳过大多数机制,会发生什么。 merge 对所有插槽都使用“最新”名称,并且:
HEAD
,除非您手动调用一些基础的 merge 机制)版本。如果在HEAD
/merge 目标中删除了文件,则此插槽为空。 gronk
flibby
cleanup
分支上,并且已将
gronk
重命名为
breem
,并对其和
flibby
进行了编辑。您决定使用
git merge work
,在那里他们修改了
gronk
,但未重命名,并删除了
flibby
。其他一些文件已干净 merge 。
bleem
和两个版本的
flibby
:
$ git checkout cleanup
Switched to branch 'cleanup'
$ git merge work
CONFLICT (modify/delete): flibby deleted in work and modified
in HEAD. Version HEAD of flibby left in tree.
Auto-merging bleem
CONFLICT (content): Merge conflict in bleem
Automatic merge failed; fix conflicts and then commit the result.
$ git ls-files --stage
100644 4362aba7f3b7abf2da0d0ed558cbf5bc0d12e4b0 1 bleem
100644 49db92a61392e9fd691c4af6e1221f408452a128 2 bleem
100644 04b399c8fe321902ce97a1538248878756678ca2 3 bleem
100644 366b52546711401122b791457793a38c033838dd 1 flibby
100644 6fecb1480f45faaabc31b18c91262d03d3767cde 2 flibby
100644 7129c6edb96d08bb44ca1025eb5ae41d41be8903 0 x.txt
bleem
查看
git show :1:bleem
的原始(基本)版本。在基本版本中(在本例中,在本例中也称为
gronk
)将其称为
work
,但现在将其称为
bleem
,因为git相信您在
gronk
中将
bleem
重命名为
cleanup
。 (在这种情况下,Git会在merge-base和
HEAD
之间找到重命名,然后在必要时对
work
应用相同的重命名。)
work
版本和
git show :3:bleem
或
git show work:gronk
,以及
HEAD
版本的任何一个:
git show HEAD:bleem
,
git show cleanup:bleem
或
git show :2:bleem
(插槽2包含
HEAD
aka
cleanup
版本,并根据
HEAD
中的名称进行命名)。
flibby
,由于已在
work
中删除,因此没有“其”(插槽3)版本。
git add
或
git rm
即可更新零槽条目并删除1至3条目。当然,使用
git add
,进入插槽0的内容现在是工作目录中的内容,因此通常必须首先编辑文件。
git checkout
对待它们的方式(
git checkout --ours
和
git checkout --theirs
使您可以将版本2或3写入插槽0;这种 checkout (与大多数 checkout 一样)也“擦除”其他插槽,从而解决了冲突)。但是,在进行重新设置的过程中,
HEAD
分支实际上是要重新建立基础的分支,而“其”版本是您正在被重新建立基础的分支。因此,在我看来,我们(他们)的术语并不是那么好:在重新设置基准期间将其倒退是很容易的。
git checkout -m
将通过擦除插槽0并根据需要“恢复”插槽1-3中的版本来“重新创建” merge 冲突(并写入冲突的将文件 merge 到工作目录,同时也要遵守
merge.conflictstyle
设置的所有更改)。
关于git - git索引的内容在 merge 期间如何演变( merge 失败后索引中的内容)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21309490/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!