- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我开发了 Magento 模块,我有两个 repos,第一个是我的模块,另一个是 Magento 本身。我将我的模块存储库克隆到目录,然后将 Magento 存储库添加为远程,并将两个分支 merge 到一个名为测试的本地分支中。它工作正常。但是在开发时我需要在编辑器中打开两个项目(模块和 Magento),所以我在测试分支中编辑代码然后我需要提交更改。但是我不能只将测试 merge 到模块分支,因为我在测试分支中有 Magento 文件,而我在模块分支中不需要这些文件。
有没有办法在没有来自 magento 分支的文件的情况下将来自测试的更改 merge 到模块分支?
子模块和子树不起作用,因为我的分支与它们的根目录重叠,模块不仅仅是 magento 分支的子目录。
谢谢。
最佳答案
您真的要将您的测试分支 merge 到您的模块分支吗?即使在您寻求的 merge 后 Magento 文件不会出现,所有 Magento 历史记录都将与您的模块分支的历史记录密不可分。这可能不是您想要的。
如果您真的想要 merge ,您可以编写自己的 merge 策略或使用git merge --no-commit
,手动删除模块分支中不需要的 Magento 文件并提交 merge 结果。如果手动删除太麻烦,您可以使用 git revert -n -m1 <unwanted-merge-id>
相反。
我建议的更简洁的解决方案是精心挑选并重新创建测试分支。您总是将 Magento 分支 merge 到您的测试分支中,我假设您在测试中没有其他 merge 。
自测试分支与当前分支的共同祖先以来,这个从测试分支中挑选(复制到当前分支)的非 merge 提交列表:
git rev-list --reverse --first-parent --no-merges ..testing | git cherry-pick --stdin
然后你可以摆脱旧的测试分支,因为它包含不必要的 merge ,并且它的内容在其他方面与你的模块分支之一相同。您可以在模块分支之上再次启动它。从您的测试分支调用 git reset --hard module
– 但请确保您事先没有未提交的更改,因为它们会丢失!
关于Git,从另外两个分支(B和C)创建本地分支(A),然后在没有C文件的情况下从A merge 到B,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10292912/
我有两种结构,Header 和Session,它们都符合协议(protocol)TimelineItem。 我有一个 Array 由 TimelineItem 组成,如下所示: [Header1, S
这个问题在这里已经有了答案: Multiple assignment and evaluation order in Python (11 个答案) 关闭 6 年前。 我刚接触python所以想问你
我试图找到一种方法来在 R 中获取 A、A、A、A、B、B、B、B、B 的所有可能的唯一排列的列表。 组合最初被认为是获得解决方案的方法,因此组合的答案。 最佳答案 我认为这就是你所追求的。 @bil
我怎样才能将两个给定的向量混合成一个新的向量,它以交替的顺序保存它们的值。 (f [a a] [b b]) ; > [a b a b] 这是我想到的: (flatten (map vector [:a
这是我的第一个问题,我开始学习Python。之间有区别吗: a, b = b, a + b 和 a = b b = a + b 当您在下面的示例中编写它时,它会显示不同的结果。 def fib(n):
这个问题在这里已经有了答案: Why is there an injected class name? (1 个回答) 12 个月前关闭。 我不知道如何解释: namespace A { struct
我尝试了一些代码来交换 Java 中的两个整数,而不使用第三个变量,使用 XOR。 这是我尝试过的两个交换函数: package lang.numeric; public class SwapVars
假设类 B 扩展类 A,并且我想为 B 声明一个变量。什么更有效?为什么? B b或 A b . 最佳答案 您混淆了两个不同的概念。 class B extends A { } 意味着B 是 A .
我不确定这个问题的标题是什么,这也可能是一个重复的问题。所以请相应地指导。 我是 python 编程的新手。我有这个简单的代码来生成斐波那契数列。 1: def fibo(n): 2: a =
我在谷歌上搜索了有关 dynamic_cast 的内容,我发现显式地将基类对象转换为派生类指针可能是不安全的。但是当我运行一些示例代码来检查它时,我没有收到任何错误。请在下面找到我的代码: class
这个问题在这里已经有了答案: What is this weird colon-member (" : ") syntax in the constructor? (14 个答案) 关闭 8 年前。
在不重现产生非整数值的表达式的情况下实现以下目标的惯用方法是什么(在我的真实情况下,该值是在我不想重现的冗长查询之后计算为百分比的): SELECT * FROM SomeTable WHERE 1/
在析构中,这两个代码的结果确实不同。我不确定为什么。 提示说 const [b,a] = [a,b] 将导致 a,b 的值为 undefined (从左到右的简单分配规则)。我不明白为什么会这样。 l
C++ Templates - The Complete Guide, 2nd Edition介绍max模板: template T max (T a, T b) { // if b < a th
我最近开始学习代码(Java),并根据第 15.17.3 节在 Oracle 网站上查找了模运算符。以下链接: http://docs.oracle.com/javase/specs/jls/se8/
无法理解以下行为。 d1 := &data{1}; 的区别d1 和 d2 := 数据{1}; &d1。两者都是指针,对吧?但他们的行为不同。这里发生了什么 package main import "f
这个问题在这里已经有了答案: How to make loop infinite with "x = y && x != y"? (4 个回答) How can i define variables
在我的程序中,当我调试我的代码时,它似乎在我生成的代码中的某处 X1=['[a,a,a]','[b,b,b]'] 还有我生成的其他地方 X2=[[a,a,a],[b,b,b]] 当我想添加这两个列表然
我试图使用递归将两个整数相乘,并意外编写了这段代码: //the original version int multiply(int a, int b) { if ( !b ) retu
我有一个列表中数字之间所有可能的操作组合: list = ['2','7','8'] 7+8*2 8+7*2 2*8+7 2+8*7 2-8*7 8-2/7 etc 我想知道是否可以说像 ('7*2+
我是一名优秀的程序员,十分优秀!