rename FONPATH to ROOTPATH; add git-ignore-find2copy.sh

This commit is contained in:
Luk
2024-01-28 09:50:54 +08:00
parent d016571ff5
commit 304d2564fa
18 changed files with 380 additions and 329 deletions

View File

@@ -2,34 +2,34 @@
if [ -d "$1" ]
then
FONPATH=$1
ROOTPATH=$1
else
echo ""
echo "=== Enter [start path] or [leave blank] for default to [[`pwd`]]"
read -p ">>> " FONPATH
read -p ">>> " ROOTPATH
echo ""
if [ ! "$FONPATH" ]
if [ ! "$ROOTPATH" ]
then
FONPATH=`pwd`
ROOTPATH=`pwd`
fi
fi
if [ ! -d "$FONPATH" ]
if [ ! -d "$ROOTPATH" ]
then
echo "××× [[$FONPATH]] not exist! Exit now. ***"
echo "××× [[$ROOTPATH]] not exist! Exit now. ***"
exit
else
echo "√√√ FONPATH = [[$FONPATH]]"
echo "√√√ ROOTPATH = [[$ROOTPATH]]"
fi
pushd $FONPATH
pushd $ROOTPATH
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
echo "======== entering [[$FONPATH/$org]] ========"
echo "======== entering [[$ROOTPATH/$org]] ========"
echo ""
cd "$org";
for repo in * ## for ??? in * 是分割成一个个目录名的,即使目录名含有空格
@@ -37,7 +37,7 @@ do
if [ -d "$repo/.git" ]
then
cd "$repo"
# echo " changing repo url to [[$FONPATH/$org/$repo]]"
# echo " changing repo url to [[$ROOTPATH/$org/$repo]]"
# git remote remove origin
# git remote add origin https://git.faronear.org/$org/$repo
# git pull