diff --git a/git-pull-all.bat b/git-pull-all.bat index 4958ee5..d7ee059 100644 --- a/git-pull-all.bat +++ b/git-pull-all.bat @@ -13,7 +13,7 @@ set FONPATH= ) 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 [.] + echo === Enter [target path] or leave [blank] for default to `.` set /p FONPATH=">>> " echo; if "" == "%FONPATH%" ( @@ -28,7 +28,7 @@ if not exist "%FONPATH%" ( ) pushd %FONPATH% -echo *** FONPATH = [%CD%] *** +echo *** Starting from [%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 ) diff --git a/git-pull-all.sh b/git-pull-all.sh index 9c7373b..ce0f59e 100755 --- a/git-pull-all.sh +++ b/git-pull-all.sh @@ -10,7 +10,7 @@ elif [ -d ~/faronear ] then FONPATH=~/faronear else - echo "=== Enter [faronear root path] or leave blank for default to [.]" + echo "=== Enter [target path] or leave [blank] for default to `.`" read -p ">>> " FONPATH echo "" if [ ! $FONPATH ] @@ -26,7 +26,7 @@ then fi pushd $FONPATH -echo "*** FONPATH = [`pwd`] ***" +echo "*** Starting from [`pwd`] ***" echo "" # for org in `ls -F | grep '/$' | grep -v '~'` ## 首先过滤出所有子目录,然后过滤出所有不含 ~ 的子目录。注意 for ??? in `ls ???` 是按照空行以及空格进行分割的,因此最后筛选出的目录名不能含有空格,否则就被分割成多个了。 diff --git a/git-pull-recursive.bat b/git-pull-recursive.bat index 523cf37..02bff0f 100644 --- a/git-pull-recursive.bat +++ b/git-pull-recursive.bat @@ -13,7 +13,7 @@ set FONPATH= ) 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 [.] + echo === Enter [target path] or leave [blank] for default to `.` set /p FONPATH=">>> " echo; if "" == "%FONPATH%" ( @@ -28,27 +28,19 @@ if not exist "%FONPATH%" ( ) pushd %FONPATH% -echo *** FONPATH = [%CD%] *** +echo *** Starting from [%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 ( +for /d /r %%r in (*) 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 ) + if exist "%%r\.git" ( + pushd "%%r" + echo ---- git pulling [%FONPATH%\%%r] ---- + git pull --all + echo; + popd + ) ) ) diff --git a/git-pull-recursive.sh b/git-pull-recursive.sh index 9430b2a..b5d8567 100644 --- a/git-pull-recursive.sh +++ b/git-pull-recursive.sh @@ -13,7 +13,7 @@ elif [ -d /mnt/d/faronear ] then FONPATH=/mnt/d/faronear else - echo "=== Enter [faronear root path] or leave blank for default to [.]" + echo "=== Enter [target path] or leave [blank] for default to `.`" read -p ">>> " FONPATH echo "" if [ ! $FONPATH ] @@ -29,12 +29,10 @@ then fi pushd $FONPATH -echo "*** FONPATH = [`pwd`] ***" +echo "*** Starting from [`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 +find . -mindepth 1 -maxdepth 3 -type d -name '?*.git' | grep -v 'node_modules' | while read repo do if [ -d "$repo/.git" ] then diff --git a/git-push-all.bat b/git-push-all.bat index eaf86c3..1b83bca 100644 --- a/git-push-all.bat +++ b/git-push-all.bat @@ -13,7 +13,7 @@ set FONPATH= ) 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 [.] + echo === Enter [target path] or leave [blank] for default to `.` set /p FONPATH=">>> " echo; if "" == "%FONPATH%" ( @@ -28,7 +28,7 @@ if not exist "%FONPATH%" ( ) pushd %FONPATH% -echo *** FONPATH = [%CD%] *** +echo *** Starting from [%CD%] *** echo; echo === Enter [commit message] or leave blank for default to 'updated' @@ -44,10 +44,10 @@ for /d %%o in (*) do ( @REM windows的链接文件会造成路径错误,从而终止该循环,从而导致下一轮乃至所有循环的工作目录错误。因此要过滤掉 .vscode 这个符号链接目录。 if not "%%o" == ".vscode" ( @REM 如果同时使用了 GIT 和 云盘进行管理,每次 git push 都会造成 .git 目录下某些文件变化,导致云盘不断自动同步。因此过滤掉云盘的目录不做更新。 - echo %%o | findstr "=" >NUL && ( - echo !!!!!!!! omitting [%FONPATH%\%%o] !!!!!!!! - echo; - ) || ( + @REM echo %%o | findstr "=" >NUL && ( + @REM echo !!!!!!!! omitting [%FONPATH%\%%o] !!!!!!!! + @REM echo; + @REM ) || ( echo ======== entering [%FONPATH%\%%o] ======== echo; pushd %%o @@ -61,7 +61,7 @@ for /d %%o in (*) do ( ) ) popd - ) + @REM ) ) ) diff --git a/git-push-all.sh b/git-push-all.sh index a174693..37947f6 100755 --- a/git-push-all.sh +++ b/git-push-all.sh @@ -10,7 +10,7 @@ elif [ -d ~/faronear ] then FONPATH=~/faronear else - echo "=== Enter [faronear root path] or leave blank for default to [.]" + echo "=== Enter [target path] or leave [blank] for default to `.`" read -p ">>> " FONPATH echo "" if [ ! $FONPATH ] @@ -26,10 +26,10 @@ then fi pushd $FONPATH -echo "*** FONPATH = [`pwd`] ***" +echo "*** Starting from [`pwd`] ***" echo "" -echo "=== Enter [commit message] or leave blank for default to 'updated'" +echo "=== Enter [commit message] or leave [blank] for default to 'updated'" read -p ">>> " COMMIT_MESSAGE if [ ! $COMMIT_MESSAGE ] then diff --git a/npm-boot-all.bat b/npm-boot-all.bat index 99676a2..4b83a0f 100644 --- a/npm-boot-all.bat +++ b/npm-boot-all.bat @@ -1,45 +1,44 @@ @echo off -@REM 首先清楚可能残留的变量 +@REM 首先清除可能残留的变量 set FONPATH= @ if not "" == "%1" ( set FONPATH=%1 ) else ( - echo === Enter [faronear root path] or leave blank for default to one of [D:\faronear], [C:\faronear], [%HOMEDRIVE%%HOMEPATH%\faronear], [.] - set /p FONPATH=">>> " - echo; -) - -@ if "" == "%FONPATH%" ( if exist D:\faronear ( set FONPATH=D:\faronear ) else (if exist C:\faronear ( set FONPATH=C:\faronear - ) else (if exist "%HOMEDRIVE%%HOMEPATH%\faronear" ( + ) else (if exist %HOMEDRIVE%%HOMEPATH%\faronear ( set FONPATH=%HOMEDRIVE%%HOMEPATH%\faronear ) else ( - set FONPATH=. + echo === Enter [target path] or leave [blank] for default to `.` + set /p FONPATH=">>> " + echo; + if "" == "%FONPATH%" ( + set FONPATH=. + ) ))) -) else ( - if not exist "%FONPATH%" ( - echo *** [%FONPATH%] not exist! Exit now. *** - @ GOTO END - ) +) + +if not exist "%FONPATH%" ( + echo *** [%FONPATH%] not exist! Exit now. *** + @ GOTO END ) pushd %FONPATH% -echo *** FONPATH = [%CD%] *** +echo *** Starting from [%CD%] *** echo; @REM for /d %%d in (*) do ( pushd %%d & ( for /d %%d in (*) do if exist %%d/package.json ( pushd %%d & echo --- npm booting: %%d ... & npm run boot & popd ) ) & popd ) for /d %%o in (*) do ( @ if not "%%o" == ".vscode" ( - @ echo %%o | findstr "=" >NUL && ( - echo !!!!!!!! omitting [%FONPATH%\%%o] !!!!!!!! - echo; - ) || ( + @REM @ echo %%o | findstr "=" >NUL && ( + @REM echo !!!!!!!! omitting [%FONPATH%\%%o] !!!!!!!! + @REM echo; + @REM ) || ( echo ======== entering [%FONPATH%\%%o] ======== echo; pushd %%o @@ -55,7 +54,7 @@ for /d %%o in (*) do ( ) ) popd - ) + @REM ) ) ) diff --git a/npm-boot-all.sh b/npm-boot-all.sh index 1a60824..1aba95c 100755 --- a/npm-boot-all.sh +++ b/npm-boot-all.sh @@ -3,31 +3,32 @@ if [ $1 ] then FONPATH=$1 +elif [ -d /faronear ] +then + FONPATH=/faronear +elif [ -d ~/faronear ] +then + FONPATH=~/faronear else - echo "=== Enter [faronear root path] or leave blank for default to one of [/faronear], [~/faronear], [.]" + echo "=== Enter [target path] or leave [blank] for default to `.`" read -p ">>> " FONPATH echo "" -fi - -if [ ! $FONPATH ] -then - if [ -d /faronear ] - then - FONPATH=/faronear - elif [ -d ~/faronear ] + if [ ! $FONPATH ] then - FONPATH=~/faronear - else FONPATH=. fi -elif [ ! -d $FONPATH ] +fi + +if [ ! -d $FONPATH ] then echo "*** [$FONPATH] not exist! Exit now. ***" exit fi pushd $FONPATH -echo "*** FONPATH = [`pwd`] ***" +echo "*** Starting from [`pwd`] ***" +echo "" + # for org in `ls -F | grep '/$' | grep -v '~'` ## 首先过滤出所有子目录,然后过滤出所有不含 ~ 的子目录。注意 for ??? in `ls ???` 是按照空行以及空格进行分割的,因此最后筛选出的目录名不能含有空格,否则就被分割成多个了。 ls -F | grep '/$' | grep -v '=' | while read org ## 换用这种方法,可以成功过滤出含有空格的完整目录名 do diff --git a/npm-clear-all.bat b/npm-clear-all.bat index 7f644fa..ac9d8c2 100644 --- a/npm-clear-all.bat +++ b/npm-clear-all.bat @@ -1,32 +1,40 @@ @echo off -echo *** Testing Path [%1] [D:\faroenar] [C:\faroenar] [%HOMEDRIVE%%HOMEPATH%\faronear] [../..] +@REM 首先清除可能残留的变量 +set FONPATH= -@ if not "%1" == "" ( - set BASEDIR=%1 -) else (if exist D:\faronear ( - set BASEDIR=D:\faronear -) else (if exist C:\faronear ( - set BASEDIR=C:\faronear -) else (if exist %HOMEDRIVE%%HOMEPATH%\faronear ( - set BASEDIR=%HOMEDRIVE%%HOMEPATH%\faronear +@ if not "" == "%1" ( + set FONPATH=%1 ) else ( - set BASEDIR=..\.. -)))) + 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 [target path] or leave [blank] for default to `.` + set /p FONPATH=">>> " + echo; + if "" == "%FONPATH%" ( + set FONPATH=. + ) + ))) +) -if not exist %BASEDIR% ( - echo *** [%BASEDIR%] not exist! Exit now. *** +if not exist "%FONPATH%" ( + echo *** [%FONPATH%] not exist! Exit now. *** @ GOTO END ) -pushd %BASEDIR% -echo *** Current path = [%CD%] *** +pushd %FONPATH% +echo *** Starting from [%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 %%o in (*) do ( - echo ======== entering [%BASEDIR%\%%o] ======== + echo ======== entering [%FONPATH%\%%o] ======== echo; pushd %%o for /d %%g in (*) do ( diff --git a/npm-clear-recursive.bat b/npm-clear-recursive.bat new file mode 100644 index 0000000..c611bcd --- /dev/null +++ b/npm-clear-recursive.bat @@ -0,0 +1,52 @@ +@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 [target path] or leave [blank] for default to `.` + set /p FONPATH=">>> " + echo; + if "" == "%FONPATH%" ( + set FONPATH=. + ) + ))) +) + +if not exist "%FONPATH%" ( + echo *** [%FONPATH%] not exist! Exit now. *** + @ GOTO END +) + +pushd %FONPATH% +echo *** Starting from [%CD%] *** +echo; + +for /d /r %%r in (*) do ( + @REM windows的链接文件会造成路径错误,从而终止该循环,从而导致下一轮乃至所有循环的工作目录错误。因此要过滤掉 .vscode 这个符号链接目录。 + if not "%%r" == ".vscode" ( + if exist "%%r\.git" ( + pushd "%%r" + echo ---- Deleting [%FONPATH%\%%r] ---- + rd /s /q node_modules + echo; + popd + ) + ) +) + +popd + +pause +@GOTO END + +:END