- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个包含两个主要分支的 Git 存储库:master 和 dev。目前看起来像这样:
master ( )----( )----(A)----(B)----(C)
\
\
dev ( )----( )----( )----( )----(~ 30 additional commits...)
非常简单,除了 master 上的提交 A 包含对文件和文件夹结构的重大更改(基本上,我使用 the steps shown here 将存储库在层次结构中向上移动一级)。
我想继续在 dev 分支上工作,但是当我试图将 dev rebase 到 master 以将新文件结构引入 dev 时,Git 出现了大量错误。我用 git reset
恢复了正常状态,但根据我(有点有限)的 Git 经验,许多错误通常意味着我采用了错误的方法。
是否有更好的方法将重组后的文件夹结构移交给 dev 分支?如果有帮助,master 上的其他提交(B 和 C)的更改非常小,如果可以让事情变得更容易,我可以接受丢失它们。
最佳答案
是的,有一种明智的方法可以做到这一点。
master
现在是(如果我理解正确的话):
project
src
file.c
dev
是,因为它不包含提交 A
:
src
file.c # with some changes
你的分支是这样的:
master ( )----(A0)----(A)----(B)----(C)
\
\
dev (D1)----(D2)----(D3)----( )----(~ 30 additional commits...)
我还假设 A
与 A0
没有任何区别,除了 project/
被插入到所有文件路径中(“移动你的tree up"进入新的 project
根目录,根据您的链接问题)。
我们做的正是 git rebase
在内部做的事情,同时在每个步骤上通过做我们自己的“cherry-pick”步骤而不是什么来愚弄 git
git
会自己做。
我们使用第二个工作目录。 $WD1
是原始工作目录的绝对路径,$WD2
是其他绝对路径(在该目录之外)。
首先,创建您的帮助目录作为原始目录的克隆:
cd $WD2
git clone $WD1 dev .
然后,开始一个分支newdev
,它最终会在A
的基础上被dev
rebased。
cd $WD1
git checkout A
git checkout -b newdev
我们将 D1
提交到 newdev
中,而不给 git
任何搞砸它的机会:
cd $WD2
git checkout D1
cd $WD1
rm -r project/src
cp -r $WD2/src project/
git add -A
git commit -m "`cd $WD2 ; git log -1 --format=%s`"
现在的情况是:
newdev (D1')
/
/
master ( )----(A0)----(A)----(B)----(C)
\
\
dev (D1)----(D2)----(D3)----( )----(~ 30 additional commits...)
现在,为 D2
重复:
cd $WD2
git checkout D2
cd $WD1
rm -r project/src
cp -r $WD2/src project/
git add -A
git commit -m "`cd $WD2 ; git log -1 --format=%s`"
现在的情况是:
newdev (D1')----(D2')
/
/
master ( )----(A0)----(A)----(B)----(C)
\
\
dev (D1)----(D2)----(D3)----( )----(~ 30 additional commits...)
重复直到完成。
当然,您会希望为这些命令创建一个小的 shell 脚本,它会遍历所有提交 D1 ... D30
。
之后,一个简单的 git rebase master
将照常从 A
rebase 到 C
。然后,通过更改周围的名称来摆脱 newdev
:
git checkout newdev
git branch olddev dev # just in case...
git branch -D dev
git checkout -b dev
为什么是第二个工作目录?
请注意,在这种特殊情况下,可能有一些方法可以避免使用辅助工作目录,方法是使用 rm -r project/src ; git checkout D1 源代码; mv src project/
直接。相反,我更喜欢按照上面所示的方式来做,只是为了 100% 确保一切都非常干净并且始终“可见”。通过这种方式, checkout 操作与我们自己应用的修改完全分开。
从字面上看,这种方式不会出错,而且该方法也适用于所有其他类型的更改。对于重要的更改,假设有人更改了 A
中每个源文件中的每个空格。这种方法使得将其他分支 rebase 到此变得微不足道(如果您也可以将该空白更改放入脚本中)。
关于带有许多移动文件和文件夹的 Git rebase/merge 分支,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41403760/
我在使用NetBeans 6.8时遇到以下问题。我通过项目属性->库->编译选项卡->添加JAR /文件夹添加带有jar的文件夹。在下一个窗口中,我选择文件夹,然后选择“复制到库文件夹”。但是,我仍然
我的网站有一个域别名。我想知道如何将 domainA.ext 的请求重定向到 https://domainA.ext/folderA和对 domainB.ext 的请求到 http://domainB
我应该在 Eclipse 中构建的 Android 项目中创建自己的自定义菜单文件夹吗?例如,我想创建一种出现在所有 Activity 中的标题。我知道菜单应该在 res/menu 文件夹中的 XML
我正在使用 VS2008 和 .net 3.5。我在我的解决方案中创建了一个类库(Myproject.Controllers)。在这个类下,我添加了一个 Controllers 文件夹。在文件夹中我添
我有一个包含生成后步骤的 Visual Studio 2012 扩展项目,我想在其中将 .dll 和 .AddIn 文件复制到当前用户的 Visual Studio 2012 AddIns 文件夹中。
我在专有的 linux 发行版中有一些自动下载。 他们去临时暂存盘。我想在它们完成后将它们 move 到主 RAID 阵列。我能看到的最好方法是检查磁盘上的文件夹,看看内容是否在最后一分钟发生了变化。
我目前正在使用 SVN 对我的软件项目进行版本控制。在一个正在进行的项目中,我有主干,用于客户的共同功能和规范以及分支,用于客户特定的。 有没有办法在每次执行此类操作时标记一些不应合并到分支中的文
这个问题在这里已经有了答案: How to exclude a directory in find . command (45 个回答) 8 年前关闭。 如何删除文件夹中的所有内容并排除特定文件夹和文
如何在特定目录中创建具有当前日期和时间的文件夹或文件? DateTimeFormatter f = DateTimeFormatter.ofPattern("uuuuMMdd HHmmss") ; L
有没有办法在系统文件资源管理器的左侧“文件夹”栏中打开文件或文件夹?如果没有这个,我必须打开文件资源管理器并一直导航到该文件夹所在的位置才能操作文件,这确实很不方便。对于大多数带有这样导航栏的工具
预期:我使用 go get 安装包,它在 src 文件夹中创建了所有必要的文件夹,但它们只出现在 pkg/mod 文件夹中,我不能使用它们。 现实:它说它正在下载,完成,然后什么都没有。 一切都在 W
说 foo.zip包含: a b c |- c1.exe |- c2.dll |- c3.dll 哪里a, b, c是文件夹。 如果我 Expand-Archive .\foo.zip -Destin
不久前我正在删除 var 文件夹中 Magento 的缓存。我可能是错的,但我认为我犯了一个错误,而不是删除 var/cache 中的所有内容,而是意外删除了 var 中的所有内容。 Magento
我在 svn 存储库的单独文件夹中有一些代码项目。 现在我在删除文件时遇到一些问题:大多数时候一切顺利,但有时当我从磁盘删除文件或文件夹时, checkin 过程会出现各种错误。 所以我想知道:在sv
有没有什么方法可以用很少的R命令行自动删除所有文件或文件夹?我知道 unlink() 或 file.remove() 函数,但对于这些函数,您需要定义一个字符向量,其中包含您想要的文件的所有名称删除。
用于在文件夹中查找不符合Get-Childitem的LastWriteTime过滤器日期范围标准的文件的powershell命令是什么? 因此,请检查目录中是否包含不包含在01/10/2012(十月1
我正在为我工作的公司内部使用的应用程序之一编写 NSIS 安装程序,安装过程工作正常,所有 REG 键都已创建,文件夹和服务也没有问题,该应用程序使用。出于某种我无法理解的原因,卸载过程不起作用。
我有一个 Excel 文件,并且在同一文件夹中还有一个包含我想要包含的 CSV 文件的文件夹。使用“来自文件夹”查询,第一步将给出以下查询: = Folder.Files("D:\OneDrive\D
我在docker中玩ScyllaDB。为了使ScyllaDB在docker生产设置中最有效地运行,它需要一个XFS格式的磁盘。 您知道如何在Linux和MacO中创建XFS容器卷,磁盘文件吗? 谢谢
我应该编写一个函数,其中包含之前每次与该数字相乘的乘积 基本上是这样的: > productFromLeftToRight [2,3,4,5] [120,60,20,5] 我应该使用高阶函数,例如折叠
我是一名优秀的程序员,十分优秀!