- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想我要找的是两个分支的最古老的共享祖先,或者类似的东西,这个问题似乎涉及到它: Finding a branch point with Git?
但我正在查看的不是 OP 中的图表,而是更多:
-- I -- I -- I -- I -- I -- I -- I (integration branch)
\ \ /
\ \ /
F -- F -- F -- F (feature branch)
我的问题是 - 如果我们从集成中 check out 一个功能分支并进行一些更改和一些提交,然后我们随着集成进行几次更新/merge 。又名,提交提交,与集成 merge ,提交提交,与集成 merge ,等等。如果我们然后做 git reset --soft <integration>
, 是在 git checkout
时将其重置为集成提交吗?被使用过,或者它只是将它重置为最后一个 git merge
所在的位置发生整合?
我的目标是让我的功能成为一个大的提交。如果git reset --soft
只追溯到最后一次 git merge with integration,那么我的功能可能有 100 次提交,这不是 bueno,我将需要另一种技术。
最佳答案
您可以使用git reset --soft
,但是您必须先做一些其他的事情——或者更确切地说,不先做。
The goal is so that I can make my feature into one big commit.
在那种情况下,请确保您不从以下内容开始:
-- o -- A -- B -- C -- D -- E -- IM <-- integration
\ \ /
\ \ /
F1 -- F2 - FM - F4 <-- feature
请注意,我已经替换了此处的单个字母,以便我可以谈论特定的提交。就 Git 本身而言,最有趣的两个提交是 F4
,这是名为 feature
的分支的尖端提交,以及 IM
,这是名为 integration
的分支的提示提交。
标记为 FM
的提交不是问题,即使它 是 merge 提交。 标记为 IM
的提交是一个问题。这是因为可以从集成
的尖端访问此提交。有关一般可达性概念的(更多)更多信息,请参阅 Think Like (a) Git .只要提交 IM
本身可以通过从 integration
指向的提交开始,然后向后(向左)工作,所有提交 IM
的提交也是如此> 本身到达。提交 IM
会返回到提交 E
(不是问题)和 F4
(有问题!)。
如果您消除提交IM
,那么您有:
-- o -- A -- B -- C -- D -- E <-- integration
\ \
\ \
F1 -- F2 - FM - F4 <-- feature
您现在可以git checkout 功能
并运行git reset --soft integration
,结果如下:
-- o -- A -- B -- C -- D -- E <-- feature (HEAD), integration
\ \
\ \
F1 -- F2 - FM - F4 [abandoned, but remembered as feature@{1}]
你的 index 和 work-tree 与你提交 F4
checkout 时没有变化,所以你现在可以运行 git commit
将当前索引变成一个新 提交。名称 feature
现在将指向新的提交:
F <-- feature (HEAD)
/
-- o -- A -- B -- C -- D -- E <-- integration
\ \
\ \
F1 -- F2 - FM - F4 [feature@{1}]
新提交 F
的快照 将匹配提交 F4
的快照:
git diff feature@{1} feature
将不打印任何内容。但是新提交 F
的 parent 是现有提交 E
。 (提交 F
也有一个新的作者和提交者以及相应的“现在”时间戳,这也将它与 F4
区分开来。)
关于git reset --soft - 它返回到 git checkout 点还是最后一个 git merge 点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52133407/
每次暂存文件时,如果您需要取消暂存文件,Git 都会提供有用的说明: (use "git reset HEAD ..." to unstage) 不过体面Git Tutorials by Atlass
我需要添加几个文件以将它们组合到一个提交中,但我必须排除其中一个。在 this answer ,执行此操作的代码是: git add -u git reset -- file_to_ignore.da
这个问题在这里已经有了答案: What are typical use cases of git-reset's --merge and --keep flags? (4 个答案) 关闭 6 年前。
有时候,进行了错误的提交,但是还没有push到远程分支,想要撤销本次提交,可以使用git reset –-soft/hard命令。 1、二者区别: git reset –-soft:回退到某个版
我认为:软重置:从重置向量启动。硬复位:拉CPU的电平。 最佳答案 硬复位当然意味着整个CPU芯片及其所有外设都被复位。造成这种情况的原因可能有很多:复位引脚被外部拉高、时钟故障、片内低电压检测、看门
$python manage.py reset Unknown command: 'reset' Type 'manage.py help' for usage. 在django 1.6中是否取消了这
我是 git 的新手,所以问题可能很简单,git reset --hard HEAD 和 git reset --hard 有什么区别? 最佳答案 HEAD 在您未指定该参数时是隐含的。 但是,您可以
我使用 apollo-link-state 来本地存储错误,但清除缓存后出现以下错误。 我已在 apollo 客户端配置选项中将 errors 的默认值设置为空数组 []。 但是,在 apolloCl
我正在使用 bool 数组来存储标志(类似于“已更改”)。数组的大小是静态的,在编译时已知。 我需要定期重置数组,即将所有元素设置为 false。我应该使用常规数组和类似 memset 或 memcp
在 git 文档(和许多 SO 线程)中,推荐使用这种重置方法: $ git reset --soft HEAD^ ;# go back to WIP state $ git reset
在我的实验中,我没能发现两者之间的任何功能差异 git reset --hard 和 git reset --merge 使用说明也没有给出任何提示 --hard res
如何重置所有列过滤器?调用 reset() 似乎重置了表,但过滤器的所有字段保持不变。 最佳答案 您可以将输入值绑定(bind)到表的过滤器,如下所示: 注意 [value] 绑定(bind)。 关
使用 std::unique_ptr::reset,您可以轻松地将您的实例恢复到新状态。 C++11 之前,为了实现类似的行为,我看到很多类都定义了一个 Reset() 方法来重置其所有内部成员。但现
为了恢复工作树和索引中的更改,此答案 ( https://stackoverflow.com/a/5812972/8278160) 建议运行以下命令: git reset --hard 运行它是否与运
我目前正在测试竞技场。我本来以为这段代码会编译,但在运行时失败了,令人惊喜的是,编译器发现了这个问题。但我不知道它的推理是否正确。有人能给我解释一下吗?。错误:。来自umpalo的相关代码:
我目前正在测试竞技场。我本来以为这段代码会编译,但在运行时失败了,令人惊喜的是,编译器发现了这个问题。但我不知道它的推理是否正确。有人能给我解释一下吗?。错误:。来自umpalo的相关代码:
我正在尝试在不触发“重置”事件的情况下重置我的收藏。我已经设置了我的收藏来收听“重置”和“添加”事件 @.listenTo(@options.muses, 'add', @addOne) @.list
根据http://en.cppreference.com/w/cpp/memory/unique_ptr/reset , void reset( pointer ptr = pointer() );
我有一个别名,unstage,用于从暂存区域中删除更改。 unstage = reset -- 我注意到 git 的帮助建议改为 git reset HEAD。我还注意到 git rm --cache
这个问题在这里已经有了答案: What's the difference between HEAD^ and HEAD~ in Git? (17 个答案) 关闭 6 年前。 git reset --
我是一名优秀的程序员,十分优秀!