shellcheck verif update git projects

This commit is contained in:
Tykayn 2022-10-20 13:41:04 +02:00 committed by tykayn
parent 79638a18d0
commit 81927a720e
1 changed files with 50 additions and 42 deletions

View File

@ -6,64 +6,72 @@
# list of framagit repos to clone. Run this command to make it work
# --------------------------------
#
#  cd ~/Téléchargements
# cd ~/Téléchargements
# curl -s https://forge.chapril.org/tykayn/scripts/raw/branch/master/update_git_projects.sh | bash
#
# --------------------------------
# liste de tous les projets pour chaque forge logicielle
declare -a list_repos_framagit=("caisse-bliss" "joinfediverse" "date-poll-api" "mastodon" "peertube" "events-liberator" "gitall" "dotclear-importer" "mobilizon" "fanzine-log" "crossed-words" "generator-tk" "circles" "card-deck" "sf-probe" "mastermind" "portfolio" "time-tracker" "cipherbliss" "caisse-bliss-frontend" "compta" "trafficjam" "ical-generator" "blueprint-cipherbliss" "dotclear2wordpress" "api" "diaspora" )
declare -a list_repos_forge_chapril=("transcription" "org-report-stats" "multi-account-post-schedule-mastodon" "framalibre-scraping" "scripts" "melting-pot" "funky-framadate-front" "rss-feeder-mobilizon" "mastodon-archive-stats" "gtg2json" "libreavous-audio-reader" "osm_my_commerce" "fromage-js" "ueberauth_openstreetmap" "events-liberator")
prefix_framagit='https://framagit.org/tykayn/'
prefix_forgechapril='https://forge.chapril.org/tykayn/'
cloning_place="/home/$USER/www/"
cd "$cloning_place" || exit
pwd
# fonction qui prend une url de base et une liste de noms de dépots à cloner
# si vous trouvez comment passer facilement un array en argument à une fonction bash, go faire la fonction pour que l'on puisse faire " pullOrCreateRepo base_url liste_de_dépots"
#function pullOrCreateRepo(){
#}
mkdir -p $cloning_place
cd $cloning_place
echo "Number of items in original list: ${#list[*]}"
# fonction qui prend une url de base et une liste de noms de dépots à cloner
function pullOrCreateRepo(){
baseUrl=$1
listOfRepos=$2
for folder_name in ${listOfRepos[@]}
do
echo "check project ${folder_name}"
if [ ! -d $folder_name ]
then
echo "cloning ${folder_name}"
git clone "${prefix_framagit}${folder_name}.git"
# test existence of a folder
# if there is no folder, clone it
# else, update with fetch from origin
else
echo "##### update project $folder_name"
cd $folder_name
git remote -v
git fetch origin
fi
done
}
# tout ceci est très verbeux.
# fonctionnement:
# lancer les clonages et git pull sur chaque dépot
# test existence of a folder
# if there is no folder, clone it
# else, update with fetch from origin
echo "----------- from framagit"
for project_name in "${list_repos_framagit[@]}";
do
cd "$cloning_place" || exit
if [ ! -d "$project_name" ]
then
echo "+++++ cloning ${project_name}"
echo "from ${prefix_framagit}${project_name}.git"
git clone "${prefix_framagit}${project_name}.git"
echo "cloning from framagit"
pullOrCreateRepo $prefix_framagit $list_repos_framagit
else
echo "##### update project $project_name"
cd "$cloning_place" || exit
git fetch origin
git config pull.ff only
git pull
fi
done
echo "cloning from forge chapril"
pullOrCreateRepo $prefix_forgechapril $list_repos_forge_chapril
echo "----------- from forge chapril"
for project_name in "${list_repos_forge_chapril[@]}";
do
cd "$cloning_place" || exit
if [ ! -d "$project_name" ]
then
echo "+++++ cloning ${project_name}"
echo "from ${prefix_forgechapril}${project_name}.git"
git clone "${prefix_forgechapril}${project_name}.git"
else
echo "##### update project $project_name"
cd "$cloning_place" || exit
git fetch origin
git config pull.ff only
git pull
fi
done
# vous pouvez ajouter vos autres dépots et lancer la fonction pullOrCreateRepo
ls -l
cd "$cloning_place" || exit
ls -l |wc -l
echo "update done"