git-pull-recursive
This commit is contained in:
parent
8557d4834d
commit
12420f26fa
60
git-pull-recursive.bat
Normal file
60
git-pull-recursive.bat
Normal 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
|
||||||
|
|
48
git-pull-recursive.sh
Normal file
48
git-pull-recursive.sh
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ $1 ]
|
||||||
|
then
|
||||||
|
FONPATH=$1
|
||||||
|
elif [ -d /faronear ]
|
||||||
|
then
|
||||||
|
FONPATH=/faronear
|
||||||
|
elif [ -d ~/faronear ]
|
||||||
|
then
|
||||||
|
FONPATH=~/faronear
|
||||||
|
elif [ -d /mnt/d/faronear ]
|
||||||
|
then
|
||||||
|
FONPATH=/mnt/d/faronear
|
||||||
|
else
|
||||||
|
echo "=== Enter [faronear root path] or leave blank for default to [.]"
|
||||||
|
read -p ">>> " FONPATH
|
||||||
|
echo ""
|
||||||
|
if [ ! $FONPATH ]
|
||||||
|
then
|
||||||
|
FONPATH=.
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d $FONPATH ]
|
||||||
|
then
|
||||||
|
echo "*** [$FONPATH] not exist! Exit now. ***"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
pushd $FONPATH
|
||||||
|
echo "*** FONPATH = [`pwd`] ***"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# for org in `ls -F | grep '/$' | grep -v '~'` ## 首先过滤出所有子目录,然后过滤出所有不含 ~ 的子目录。注意 for ??? in `ls ???` 是按照空行以及空格进行分割的,因此最后筛选出的目录名不能含有空格,否则就被分割成多个了。(for ??? in * 是分割成一个个目录名的,即使目录名含有空格。)
|
||||||
|
# ls -F | grep '/$' | grep -v '=' | while read org ## 换用这种方法,可以成功过滤出含有空格的完整目录名
|
||||||
|
find . -mindepth 2 -maxdepth 3 -type d -name '?*.git' | grep -v 'node_modules' | while read repo
|
||||||
|
do
|
||||||
|
if [ -d "$repo/.git" ]
|
||||||
|
then
|
||||||
|
echo "---- git pulling [`pwd`/$repo] ----"
|
||||||
|
pushd "$repo"
|
||||||
|
git pull --all
|
||||||
|
echo ""
|
||||||
|
popd
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
popd
|
Loading…
Reference in New Issue
Block a user