git-pull-recursive

This commit is contained in:
luk.lu
2022-10-17 11:40:49 +08:00
parent 8557d4834d
commit 12420f26fa
2 changed files with 108 additions and 0 deletions

60
git-pull-recursive.bat Normal file
View File

@@ -0,0 +1,60 @@
@echo off
@REM 首先清除可能残留的变量
set FONPATH=
@ if not "" == "%1" (
set FONPATH=%1
) else (
if exist D:\faronear (
set FONPATH=D:\faronear
) else (if exist C:\faronear (
set FONPATH=C:\faronear
) else (if exist %HOMEDRIVE%%HOMEPATH%\faronear (
set FONPATH=%HOMEDRIVE%%HOMEPATH%\faronear
) else (
echo === Enter [faronear root path] or leave blank for default to one of [.]
set /p FONPATH=">>> "
echo;
if "" == "%FONPATH%" (
set FONPATH=.
)
)))
)
if not exist "%FONPATH%" (
echo *** [%FONPATH%] not exist! Exit now. ***
@ GOTO END
)
pushd %FONPATH%
echo *** FONPATH = [%CD%] ***
echo;
@REM for /d %%d in (*) do ( pushd %%d & ( for /d %%d in (*) do ( if exist %%d/.git pushd %%d & echo --- git pulling: %%d ... & git pull & popd ) ) & popd )
for /d /r %%r in (*.git) do (
@REM windows的链接文件会造成路径错误从而终止该循环从而导致下一轮乃至所有循环的工作目录错误。因此要过滤掉 .vscode 这个符号链接目录。
if not "%%r" == ".vscode" (
@REM 如果同时使用了 GIT 和 云盘进行管理,每次 git pull 都会造成 .git 目录下某些文件变化,导致云盘不断自动同步。因此过滤掉云盘的目录不做更新。
@REM echo %%o | findstr "=" >NUL && (
@REM echo !!!!!!!! omitting [%FONPATH%\%%r] !!!!!!!!
@REM echo;
@REM ) || (
if exist "%%r\.git" (
pushd "%%r"
echo ---- git pulling [%FONPATH%\%%r] ----
git pull --all
echo;
popd
)
@REM )
)
)
popd
:END
pause