merge *-all.* into *-recursive.*

This commit is contained in:
Luk Lu
2023-01-12 19:18:22 +08:00
parent 3dfa327b22
commit 6555284efc
13 changed files with 196 additions and 540 deletions

View File

@@ -20,7 +20,6 @@ then
elif [ -d $FONPATH4 ]
then
FONPATH=$FONPATH4
else
echo "=== Enter [fonpath] or leave [blank] for default to '.'"
read -p ">>> " FONPATH
@@ -51,15 +50,39 @@ then
fi
echo ""
find . -mindepth 1 -maxdepth 3 -type d -name '[^.]*' | grep -E -v 'node_modules uni_modules .deploy_git .git .svn .vscode unpackage _webroot _logstore _datasotre _archive _filestore _ssl' | while read repo
do
if [ -d "$repo/.git" ]
then
echo "---- git commit & push [$repo] ----"
pushd "$repo"
git add . && git commit -m "$COMMIT_MESSAGE" && git push
if [ "$2" == 'hier' ]
then
# for org in `ls -F | grep '/$' | grep -v '~'` ## 首先过滤出所有子目录,然后过滤出所有不含 ~ 的子目录。注意 for ??? in `ls ???` 是按照空行以及空格进行分割的,因此最后筛选出的目录名不能含有空格,否则就被分割成多个了。
ls -F | grep '/$' | grep -v 'node_modules' | while read org ## 换用这种方法,可以成功过滤出含有空格的完整目录名
do
echo "======== entering [$FONPATH/$org] ========"
echo ""
popd
fi
done
cd "$org";
for repo in * ## for ??? in * 是分割成一个个目录名的,即使目录名含有空格
do
if [ -d "$repo/.git" ]
then
echo "---- git commit & push [`pwd`/$repo] ----"
pushd "$repo"
git add . && git commit -m "$COMMIT_MESSAGE" && git push
echo ""
popd
fi
done
cd ..
done
else
find . -mindepth 1 -maxdepth 3 -type d -name '[^.]*' | grep -E -v 'node_modules uni_modules .deploy_git .git .svn .vscode unpackage _webroot _logstore _datasotre _archive _filestore _ssl' | while read repo
do
if [ -d "$repo/.git" ]
then
echo "---- git commit & push [$repo] ----"
pushd "$repo"
git add . && git commit -m "$COMMIT_MESSAGE" && git push
echo ""
popd
fi
done
fi
popd