- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个存在于两个SVN存储库中的项目。第二个SVN储存库是通过从旧SVN储存库的检出中添加储存库而创建的,而没有剥离SCM信息。文件的内容字节相同,但是没有关联的SCM元数据。
我已经使用了新的SVN存储库,并通过git-svn将其移植到Git存储库中。现在,我想导入旧的存储库,并以某种方式将其链接到新的存储库,这样我就可以看到两者的历史记录。是否有一种简单的方法,而无需手工将两个存储库缝合在一起?
最佳答案
另请参见:如何在我在github.com上创建的项目之上重播对本地Git存储库的提交?问题(和我的回答),尽管情况略有不同,但我认为。
您至少有三种可能性:
使用grafts合并两个历史记录,但不要重写历史记录。这意味着您(以及拥有相同移植的任何人)将具有完整的历史记录,而其他用户则具有较小的存储库。如果有人已经开始使用较短的历史记录在转换后的存储库上进行操作,这还可以避免历史记录重写的问题。
使用嫁接连接两个历史记录,并使用“ git log”或“ gitk”(或其他Git历史记录浏览器/查看器)检查其是否正确,然后使用git filter-branch重写历史记录;那么您可以删除嫁接文件。这意味着从重写的存储库中克隆(获取)的每个人都将获得完整的联合历史记录。但是,如果有人已经基于转换后的短期存储库进行了工作,那么重写历史记录就大不了(但是这种情况可能不适用于您)。
使用git replace合并两个历史记录。这将使人们可以选择获取refs/replace/
(然后获得完整的历史记录)或不获取(然后获得简短的历史记录),从而选择是要完整的历史记录,还是仅需要当前的历史记录。不幸的是,这要求当前使用尚未发布的Git版本,开发版本(“主版本”)或1.6.5的候选版本之一。 refs/replace/
层次结构计划用于即将发布的Git版本1.6.5。
下面是所有这些方法的分步说明:嫁接(本地),使用嫁接的重写历史记录以及refs / replace /。
在所有情况下,我都假设您在一个存储库中同时拥有当前和历史存储库历史记录(可以使用git remote add从另一个存储库中添加历史记录)。我还假定短历史存储库中的分支(之一)被称为“ master”,而您想要附加当前历史记录的历史存储库中的分支(“提交”)被称为“ history”。您将不得不替换自己的分支名称(或提交ID)。
查找要附加的提交(简短历史记录的根)
首先,您必须在要附加到完整历史记录的短历史记录中找到(的SHA-1标识符)提交。这将是短期历史中的第一个提交,即根提交(没有任何父母的提交)。
有两种找到它的方法。如果确定没有其他根提交,则可以使用以下拓扑以拓扑顺序找到最后一个(最底)提交:
$ git rev-list --topo-order master | tail -n 1
tail -n 1
用于获取输出的最后一行;如果没有它,则不需要使用它。)
$ git rev-list --parents master | grep -v ' '
grep -v ' '
,即单引号之间的空格,用于过滤所有具有任何父项的提交)。然后,您必须检查(例如使用“
git show <commit>
”)那些提交(如果有多个),并选择要附加到较早历史记录的提交。
$ TAIL=$(git rev-list --topo-order master | tail -n 1)
$TAIL
来表示您必须替换当前(简短)历史记录中最底层提交的SHA-1 ...或允许shell替您替换。
$ git rev-parse --verify history^0
$ TOP=$(git rev-parse --verify history^0)
.git/info/grafts
中的嫁接文件(如果不存在,则需要创建此文件,如果要使用此机制,则需要创建该文件)用于替换提交的父信息。它是基于行的格式,其中每行包含我们要修改的提交的SHA-1,后跟零个或多个以空格分隔的提交列表,这些列表是我们希望给定提交作为父级提交的;与“
git rev-list --parents <revision>
”输出的格式相同。
info/grafts
文件中,应该在$ TAIL提交的SHA-1行中用$ TOP提交的SHA-1隔开空格。您可以为此使用以下单行代码(另请参见
git filter-branch文档中的示例):
$ echo "$TAIL $TOP" >> .git/info/grafts
$ git filter-branch $TOP..master
$ git filter-branch --all
refs/original/
中的备份(有关详细信息,请参见“ git filter-branch”的文档)。
$ git cat-file commit $TAIL > TAIL_COMMIT
tree 2b5bfdf7798569e0b59b16eb9602d5fa572d6038author Joe R Hacker 1112911993 -0700committer Joe R Hacker 1112911993 -0700Initial revision of "project", after moving to new repository
Now you need to add $TOP as parent, by putting a line with "parent $TOP" (where $TOP has to be expanded to SHA-1 id!) between 'tree' header and 'author' header. After editing 'TAIL_COMMIT' it should look like this:
tree 2b5bfdf7798569e0b59b16eb9602d5fa572d6038parent 0f6592e3c2f2fe01f7b717618e570ad8dff0bbb1author Joe R Hacker 1112911993 -0700committer Joe R Hacker 1112911993 -0700Initial revision of "project", after moving to new repository
If you want, you can edit the commit message.
Now you need to use git hash-object to create a new commit in the repository. You need to save the result of this command, which is the SHA-1 of a new commit object, for example like this:
$ NEW_TAIL=$(git hash-object -t commit -w TAIL_COMMIT)
-w
'选项将对象实际写入存储库)。
$ git replace $TAIL $NEW_TAIL
+refs/replace/*:refs/replace/*
'作为pull refspecs之一。
关于svn - 如何将历史记录添加到Git存储库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1220557/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!