六个仓库合并为一个仓库,保留master和develop分支的bat脚本

利用git subtree可以实现多个仓库合并为一个仓库,手动操作起来太麻烦了,今天花了点时间写了一个可执行的脚本,现在操作起来就方便多了。

1、本地新建setup.bat文件

2、用编辑器打开(我用的是Notepad++)

3、把下面代码复制进去

下面是六个代码仓库(在远程仓库,需要拉取)拉取合并为一个仓库的脚本,根据实际情况修改合并后目录、仓库地址等

powershell 复制代码
@echo off
setlocal enabledelayedexpansion

:: 1. 强制清理旧目录
:: project-dir是合并后目录
set projectdir=project-dir
rd /s /q %projectdir% 2>nul
mkdir %projectdir%
cd %projectdir%

:: 2. 初始化仓库并创建 master 分支
git init
git commit --allow-empty -m "Initial empty commit (master)"

:: 3. 添加子项目远程仓库
:: 目录和仓库地址都是虚假替代的
git remote add dir1 https://gitee.com/3539949703/dir1.git
git remote add dir2 https://gitee.com/3539949703/dir2.git
git remote add dir3 https://gitee.com/3539949703/dir3.git
git remote add dir4 https://gitee.com/3539949703/dir4.git
git remote add dir5 https://gitee.com/3539949703/dir5.git
git remote add dir6 https://gitee.com/3539949703/dir6.git

:: 4. 定义子项目列表
set "subprojects=dir1 dir2 dir3 dir4 dir5 dir6"

:: 5. 在 master 分支添加子项目的 master 分支
for %%i in (%subprojects%) do (
    git subtree add --prefix=%%i %%i master --squash
)

:: 6. 创建 develop 分支
git checkout --orphan develop
git reset --hard
:: 确保 develop 分支有初始提交
git commit --allow-empty -m "Initial empty commit (develop)"

:: 7. 添加子项目的 develop 分支
for %%i in (%subprojects%) do (
    git subtree add --prefix=%%i %%i develop --squash
)

endlocal

pause

4、打开Git Bash客户端,执行./setup.bat,就完成合并为一个仓库的任务。


5、查看了下提交的代码,做了两次commit提交,感觉git commit --allow-empty -m "Initial empty commit (master)"git commit --allow-empty -m "Initial empty commit (develop)"这两次提交没有必要,所以更新了下合并脚本,如下:

powershell 复制代码
@echo off
setlocal enabledelayedexpansion

set projectdir=maven-project
cd %projectdir%

set "subprojects=dir1 dir2 dir3 dir4 dir5 dir6"

:: 更新 master 分支
git checkout master
for %%i in (%subprojects%) do (
    :: 强制重置子项目目录
    git checkout HEAD -- %%i
    :: 强制拉取远程代码(丢弃本地修改)
    git subtree pull --prefix=%%i %%i master --squash --force
)

:: 更新 develop 分支
git checkout develop
for %%i in (%subprojects%) do (
    :: 强制重置子项目目录
    git checkout HEAD -- %%i
    :: 强制拉取远程代码(丢弃本地修改)
    git subtree pull --prefix=%%i %%i develop --squash --force
)

endlocal

pause

6、合并后,同事又继续提交代码到旧仓库,所以就又写了一个更新代码的脚本,命名为update.bat,源码放在下面,执行步骤跟setup.bat一样,不赘述了。

powershell 复制代码
@echo off
setlocal enabledelayedexpansion

set projectdir=ewp-cloud
cd %projectdir%

set "subprojects=dir1 dir2 dir3 dir4 dir5 dir6"

:: 更新 master 分支
git checkout master
for %%i in (%subprojects%) do (
    :: 强制重置子项目目录(丢弃本地修改)
    git checkout HEAD -- %%i
    :: 拉取远程代码(去掉 --force)
    git subtree pull --prefix=%%i %%i master --squash
)

:: 更新 develop 分支
git checkout develop
for %%i in (%subprojects%) do (
    :: 强制重置子项目目录(丢弃本地修改)
    git checkout HEAD -- %%i
    :: 拉取远程代码(去掉 --force)
    git subtree pull --prefix=%%i %%i develop --squash
)

endlocal

pause
相关推荐
德育处主任4 小时前
聚沙成塔,三步成书:GitBook极简入门教程
前端·git·电子书
m0_635647484 小时前
git管理github上的repository
git·github
Jiude4 小时前
基于开源项目开发公司项目,如何同步开源仓库的最新更新(以vben为例)
git·开源·github
PAK向日葵4 小时前
【软件工程】如何使用Git Rebase同步团队开发进度
git·面试
枫叶落雨2227 小时前
git checkout C1解释
git
Dontla8 小时前
git stash介绍(临时保存当前工作目录中尚未提交的修改)
git
黎相思9 小时前
Git多人协作
git
一只名叫Me的猫10 小时前
Git 常用命令 - 服务器用
git
黎相思10 小时前
Git基本操作
git
Auv开心20 小时前
【git stash切换】
经验分享·git