rabowl
的git submodule
版本
子应用的多git
库也可以使用 git submodule
来进行管理。
添加子应用
在主应用目录下执行命令
git submodule add -b feature/xxx/xxxx --name app1 http://xxxxx.git(子应用 git 地址) packages/app1
添加子应用后在主应用目录下会自动生成一个 .gitmodules
文件。里面会自动添加一条记录
[submodule "app1"]
path = packages/app1
url = http://xxxxx.git
branch = feature/xxx/xxxx
子应用提交
子应用更新提交可以使用 git submodule
命令
git submodule foreach git add .
git submodule foreach git commit -m"xxxx"
git submodule foreach git pull
git submodule foreach git push origin
子应用提交后,主应用也需要git add .
和 git commit -m"xxxx"
以及 git push origin
将本地的子应用commit id
同步到git
库。这样其他人clone
你的代码后 可以通过以下命令进行同步。
git submodule init && git submodule update
rabowl ready
命令修改
之前rabowl ready
命令会自动clone
子应用并切换子应用分支到指定分支。现在我们不需要这些功能了,会与git submodule
产生冲突。但是我们还是需要 rabowl ready
来生成打包命令。因此我们需要修改rabowl
目录下的 src/readyAllApp.ts
文件中的cloneAndCheckout
函数
// clone并checkout 子应用
async function cloneAndCheckout(packagesPath: string, appList: any[]) {
await Promise.all(
appList.map(async (app) => {
// 首先清理对应的app目录
// await deleteFile(`/packages/${app.name}`);
// await deleteFile(`/packages/${app.gitName}`);
// // 从 git 库将子应用 clone 下来
// const cloneCode = await spawnSync('git', ['clone', app.git], {
// cwd: packagesPath,
// title: `git clone ${app.git}`,
// });
// if (!fs.existsSync(path.join(packagesPath, app.gitName))) {
// return cloneCode;
// }
// fs.renameSync(
// path.join(packagesPath, app.gitName),
// path.join(packagesPath, app.name),
// );
// const checkoutCode = await spawnSync('git', ['checkout', app.branch], {
// cwd: path.join(packagesPath, app.name),
// title: `git checkout ${app.branch}`,
// });
const checkoutCode = await spawnSync('git', ['branch'], {
cwd: path.join(packagesPath, app.name),
title: 'git branch',
});
return checkoutCode;
}),
);
}
修改完成后,在主应用下执行npm run build:cli
命令。
另外,packages/config.json
文件中的配置目前只有active
属性有用了,这里可以控制你 rabowl ready
生成的命令涉及的子应用的范围。不需要打包的子应用配置为false
就可以了。