我开始学习 git 1.8.2 中的子树合并。我创建了一个简单的示例来测试对迁移到主项目的第三方 repo 的更改。
我正在关注6.7 Git Tools - Subtree Merging示例。
“子”项目作为子目录包含在“主”项目中。
在我对“子”项目进行更改后,当我尝试将更改合并到“主”项目中时,git 会报告冲突。
测试总结
- 为项目'main'和'sub'创建了repos(sub而不是rack)
- 将名为 sub_remote 的远程添加到引用 sub 的 main
- 使用 sub_branch 跟踪 sub_remote
- 在“子”项目的文件中更改并提交一行
- 将更改从 sub 拉到 main/sub_branch
- 将 main/sub_branch 合并到 main/master。
合并因冲突而失败。Merge 对要保留哪个版本的更改行感到困惑。
<<<<<<< HEAD
main
=======
main upstream change
>>>>>>> sub_branch
main.git
sub
sub.git
tm
完整的测试脚本
#!/bin/sh
# initialize empty repos
for i in main sub
do
rm -rf $i{,.git}
mkdir $i.git
cd $i.git;
git --bare init;
cd ..;
git clone $i.git
cd $i
echo $i > readme.md
git add readme.md
git commit -a -m "added readme.md"
git push origin master
cd ..
done
# add data to sub
ls > sub/data
cd sub
git add data
git commit -m "Added data"
git push origin master
cd ..
# add sub as a sub-tree in main
cd main
git remote add sub_remote ../sub.git
git fetch sub_remote
git checkout -b sub_branch sub_remote/master
git checkout master
git read-tree --prefix=sub/ -u sub_branch
git commit -m "Added sub"
git push origin master
cd ..
# make change to sub
cd sub
sed -i -e 's/main$/main upstream change/' data
git commit -a -m "upstream change made to data"
git push origin master
cd ..
# merge sub change to main
cd main
git checkout sub_branch
git pull
#merge sub_branch changes into master
git checkout master
git merge -s subtree sub_branch
cat sub/data