六个仓库合并为一个仓库,保留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
相关推荐
海域云赵从友12 小时前
2025年印尼服务器选型指南:跨境业务落地的合规与性能双解
人工智能·git·github
不会写代码的里奇12 小时前
VMware Ubuntu 22.04 NAT模式下配置GitHub SSH完整教程(含踩坑实录+报错_成功信息对照)
linux·经验分享·笔记·git·ubuntu·ssh·github
2501_9371931413 小时前
PLB-TV 影视!无广告 + 4K 高清
android·源码·源代码管理·机顶盒
木子杳衫15 小时前
【Git】处理报错原因
git
SHIPKING39315 小时前
【Git】2025全图文详解安装教程
git
无限进步_16 小时前
C语言atoi函数实现详解:从基础到优化
c语言·开发语言·c++·git·后端·github·visual studio
地球没有花1 天前
gitlab cicd首次操作
运维·git·ci/cd·gitlab
无限进步_2 天前
【C语言】贪吃蛇游戏设计思路深度解析:从零开始理解每个模块
c语言·开发语言·c++·git·游戏·github·visual studio
达子6662 天前
git使用应用实战大全
git
2501_937154932 天前
神马影视 8.8 源码 2025 版,HDR + 杜比音效 + 零卡顿
android·源码·源代码管理·机顶盒