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

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

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

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

etc.


当前回答

ls | xargs -I{} git -C {} pull

并行地做:

ls | xargs -P10 -I{} git -C {} pull

其他回答

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

npm install gitfox -g
g pull

如果你有很多git仓库的子dirs,你可以使用parallel

ls | parallel -I{} -j100 '
  if [ -d {}/.git ]; then
    echo Pulling {}
    git -C {} pull > /dev/null && echo "pulled" || echo "error :("
  else
     echo {} is not a .git directory
  fi
'

这应该是自动发生的,只要cms, admin和chart都是存储库的一部分。

一个可能的问题是这些插件都是git子模块。

运行git帮助子模块查看更多信息。

EDIT

在bash中这样做:

cd plugins
for f in cms admin chart
do 
  cd $f && git pull origin master && cd ..
done

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

ls | parallel git -C {} pull

比里奥的解决方案更低技术含量:

for i in */.git; do ( echo $i; cd $i/..; git pull; ); done

这将更新工作目录中的所有Git存储库。不需要显式列出他们的名字(“cms”,“admin”,“chart”)。“cd”命令只影响子shell(使用圆括号派生)。