如何从共享父目录更新多个git存储库,而不用cd'ing到每个repo的根目录?我有以下所有单独的git存储库(不是子模块):

/plugins/cms
/plugins/admin
/plugins/chart

我想一次更新它们,或者至少简化我当前的工作流程:

cd ~/plugins/admin
git pull origin master
cd ../chart
git pull

etc.


当前回答

2010年原答案:

如果所有这些目录都是单独的git repo,则应该将它们作为子模块引用。

这意味着你的“起源”将是远程回购“插件”,其中只包含对子回购“cms”,“管理”,“图表”的引用。

git拉出,然后更新git子模块,就可以实现你想要的结果。


2016年1月更新:

在Git 2.8(2016年第一季度)中,你将能够使用Git fetch——recursive -submodules -j2并行地获取子模块。 参见“如何使用git克隆-递归加速/并行化git子模块的下载?”

其他回答

从父目录运行以下命令,在本例中是插件:

find . -type d -depth 1 -exec git --git-dir={}/.git --work-tree=$PWD/{} pull origin master \;

澄清:

找到。搜索当前目录 -type d查找目录,而不是文件 -depth 1表示最大一个子目录深度 -exec {} \;为每次查找都运行自定义命令 git - git-dir ={} /。git——work-tree=$PWD/{} pull git获取单个目录

要使用find,我建议使用echo after -exec来预览,例如:

find . -type d -depth 1 -exec echo git --git-dir={}/.git --work-tree=$PWD/{} status \;

注意:如果没有-depth 1选项,请尝试-mindepth 1 -maxdepth 1。

实际上,如果你不知道子文件夹是否有一个git repo,最好是让find get repos为你:

find . -type d -name .git -exec git --git-dir={} --work-tree=$PWD/{}/.. pull origin master \;

PowerShell的等效代码是:

Get-ChildItem -Recurse -Directory -Hidden -Filter .git | ForEach-Object { & git --git-dir="$($_.FullName)" --work-tree="$(Split-Path $_.FullName -Parent)" pull origin master }

最紧凑的方法,假设所有子dirs都是git回购:

ls | parallel git -C {} pull

我用这个

for dir in $(find . -name ".git")
do cd ${dir%/*}
    echo $PWD
    git pull
    echo ""
    cd - > /dev/null
done

Github

Gitfox是一个在所有子回购上执行命令的工具

npm install gitfox -g
g pull