- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
假设我有两个基于相同初始内容创建的存储库。例如,如果我使用 git 来管理/etc/apache2 中的 apache 配置文件,并且我分别在 machine-a 和 machine-b 上运行 git init
。
从那以后,我对 machine-b 进行了一些配置更改,我想将这些更改应用于 machine-a 上的配置,而不会覆盖主机名等不常见的内容。
如果我这样做:
machine-a% remote add machine-b ssh://...
machine-a% git fetch machine-b
我得到了 machine-b 上的所有提交,GitX 显示了一组完全断开的提交,正如我所期望的那样。
但是,如果我尝试 merge machine-b 的任何更改,我会在所有修改的行上发生冲突。
就我的目的而言,这已经足够了,但我想知道是否有更清洁的解决方案?
最佳答案
你可能想看看 git grafts。此处提供了一些信息:http://git-scm.com/docs/git-filter-branch
基本上,您要做的是伪造祖先。
您在两台机器上都进行了初始提交——我们称它们为“baseA”和“baseB”。然后,您在两侧创建了第二个提交——“secondA”和“secondB”。你想要做的是告诉 git 'secondB' 没有 'baseB' 作为祖先,而是有 'baseA' 作为父级。
你可以通过移植来做到这一点。例如,将其放入您的 .git/info/grafts 文件中:
secondB baseA
(但随后使用真正的 SHA)。现在,如果您查看 GitX,您会发现历史是相互关联的。要使更改永久生效,您需要运行 git filter-branch。
我不确定您所做的是否“正确”,尽管它会起作用。如果你做什么你做到了,你会得到历史:
BaseA --- SecondA -- .. - .. - Merge
\ BaseB --- SecondB ... - .. /
哪个会起作用(并且 merge 会毫无问题地成功)。然而,什么是更好一点的是:
BaseA --- SecondA -- .. - .. - Merge
\ SecondB ... - .. /
基本上将“BaseA”作为提交并将“BaseA”设置为父级第二 B.这应该可以使用我告诉过你的嫁接规则。
为了演示这一点,我创建了一个小型存储库,您可以下载 here .
如果你查看 GitX 中的历史记录(“gitx master second_master”),你会看到历史是断开的。如果将 .git/info/_grafts 文件移动到 .git/info/grafts,您将获得第二个漂亮的历史记录。
我还添加了一个 .git/info/wrong_grafts 文件。如果您使用那个,您将获得您创建的历史记录。
如果查看 grafts 文件中的 SHA,您会发现 _grafts 文件基本上包含以下内容:
SecondB BaseA
wrong_grafts 文件有这个:
BaseB BaseA
关于git - 有没有一种干净的方法来处理两个以相同内容开头的原始 git 存储库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/394647/
2种参数:尺寸和价格。目前,我只能单击选择/突出显示尺寸列中的一个,也只能单击选择/突出显示价格列中的一个,而不会影响另一个列中的一个。 当我点击尺寸时,会添加一个 URL 参数“#size=4”。单
在css命名约定中,有什么原因,一些object最好以前缀o-和component开头> 以 c- 开头? 我知道 o- 代表 object 而 c- 代表 component,但为什么不呢?难道我们
这就很迷惑了,一下子,下面的代码就不行了。尝试让我的 Android 很好地显示网页已经显示的内容: HttpClient httpclient = new DefaultHttpClient();
我正在将我的网站发布到我无法控制的 IIS 服务器,我想从代码隐藏中了解它的 URL 是否以“http”或“https”开头。 首先,我在本地尝试了这两种解决方案,都返回了正确的值(“http”):
如果我运行: sbin/start-dfs.sh 然后它实际上并没有启动一个名称节点尽管打印: Starting namenodes on [0.0.0.0] 0.0.0.0: starting na
我正在开发一个包含一些数组的模块。现在我的数组包含: $omearray = array ( '#title' = 'title', 0 = array ( 'another array',
对于 PMD,我希望有一个规则来警告我那些以 my 开头的丑陋变量。 这意味着我必须接受所有不以my开头的变量。 所以,我需要一个正则表达式(re),其行为如下: re.match('myVar')
出于某种奇怪的原因,当我尝试使用 URLConnection 获取网页源时,我在输出中得到“null”。有人可以解释一下吗? 我的方法: public String getPageSource()
如何批量检查某个字符串(记录文本文件中的行)是否以特定单词开头? 我知道如何检查句子/行(字符串)中是否存在单词(子字符串),但我如何检查天气是否以这个词开头? 谢谢:) 最佳答案 这可以通过 FIN
我有一个列表,其中包含多个网址和一些字符串,例如#skipsideNav、#content。我正在从这些字符串中分离出 url if link.startswith('/'): local_u
我有以下 html 标记: 我想选择类 bubble bubble_white 和 bubble bubble_black。我正在考虑下面的代码,但它不起作用: $(".bubbl
我有一个用于文件名验证的正则表达式。在这里: /^[0-9a-zA-Z\^\&\'\@\{\}\[\]\,\$\=\!\-\#\(\)\.\%\+\~\_; ]+$/ 如何更改它以检查文件名不是以
我正在构建一个自动填充函数,它接受一个字符串输入并返回一个字符串建议列表。 Sequelize 的 iLike:query返回出现查询字符串的每个字符串。我想支持查询是前缀的字符串。例如当query=
我首先知道这可能是有史以来看起来最糟糕的正则表达式,但这里是。 我有这个正则表达式 (?:http://)?(?:www.)?youtu(?:be)?.(?:[a-z]){2,3}(?:[a-z/?=
尝试读取文件并根据行创建字典,跳过以#符号开头的行 文件示例: param1=val1 # here is comment 我的功能: def readFromFile(name): conf
我的程序正在读取文本文件并根据文本执行操作。但是文本的第一行是有问题的。显然它以“”开头。这弄乱了我的 startsWith() 检查。 为了理解这个问题,我使用了这段代码: System.ou
我的印象是变量名只能以字母和 _ 开头,但是在测试时,我还发现变量名可以以 $ 开头,如下所示: 代码 #include int main() { int myvar=13; int
我试过这个... Dim myMatches As String() = System.Text.RegularExpressions.Regex.Split(postRow.Item("Post")
开头
我正在使用CKEditor,默认情况下在内容的开头添加了。 即使将enterMode设置为,它也只会影响Enter键的作用,并保留开始的。 我遇到的问题是,如果文本以标记开头,它将围绕它包装,并且图像
我有一个List ,其中有五个字符串: abc def ghi jkl mno 我还有另一个字符串“pq”,我需要知道列表中的每个字符串是否都不以“pq”开头-我将如何使用LINQ(.NET 4.0)
我是一名优秀的程序员,十分优秀!